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呈 
ll 


学 习 语 言 的 目的 是 为 了 开发 项 目 ， 很 多 初学 者 对 于 学 习 技 术 没 有 问题 ,但 要 真正 开发 
项 目 ， 就 会 感到 迷茫 和 手足 无 措 。 而 对 于 即将 毕业 的 学 生来 说 ， 提 交 的 毕业 设计 又 会 让 他 
们 感到 焦头烂额 。 

为 了 帮助 读者 解决 这 些 问 题 ， 引 导读 者 学 有 所 用 ， 特 编写 了 本 书 ， 内 容 涉及 PHP 开发 
的 主流 开发 技术 ， 并 以 最 简单 通俗 的 方式 向 读者 介绍 如 何 开发 Web 项 目 。 相 信 通 过 本 书 
的 学 习 , 读者 会 在 PHP 项目 开发 的 道路 上 积累 更 多 的 实战 经 验 ， 掌 握 项 目 开 发 的 方法 。 同 
时 ， 也 为 正在 忙于 毕业 设计 的 同学 提供 了 一 条 捷径 。 

如 果 读 者 在 学 习 的 过 程 中 遇 到 问题 ， 可 以 通过 QQ、 论 坛 等 方式 与 我 们 联系 ， 我 们 会 
力争 排除 读者 在 PHP 学 习 过 程 中 遇 到 的 各 种 障碍 。 


本 书 内 容 


本 书 分 为 8 章 ， 其 中 包括 6 个 实用 项 目 和 2 个 毕业 设计 。 实 用 项 目 包括 图 书信 息 管 理 
系统 、 俊 羽 会 议 管理 系统 、 梦 幻 网 络 日 记 、 企 业 网 站 系统 、 明 日 网 上 书店 和 问鼎 办 公 自 动 
化 系统 的 设计 ， 毕 业 设 计 包 括 图 书馆 管理 系统 和 电子 商务 网 站 的 设计 。 


本 书 特 色 


加 ”技术 丰富 : 本 书 从 实际 应 用 的 角度 出 发 ， 运 用 最 简洁 、 最 实用 的 技术 开发 最 流行 
的 项 目 。 如 PHP 操作 MySQL 数据 库 、Smarty 模板 、PDO 和 ADODB 数据 库 抽 
象 层 等 技术 。 

回 ”横向 扩展 : 本 书 属于 PHP 系列 图 书 的 一 部 分 ,在 经 过 了 基础 、 范 例 和 典型 模块 等 
内 容 的 学 习 后 ， 以 此 来 检验 读者 的 学 习 成 果 ， 体 会 Web 项 目 开发 的 过 程 ， 积 累 实 

回 ”讲解 到 位 : 本 书 对 每 个 项 目 中 最 有 价值 的 部 分 进行 了 剖析 ， 以 达到 画龙点睛 的 

目的 。 

赠送 项 目 源 代码 和 毕业 设计 论文 : 书 中 所 有 项 目 均 提供 有 源 代码 ， 用 户 在 开发 中 

可 以 快速 借鉴 或 应 用 ， 并 且 提 供 了 两 篇 毕业 设计 论文 ， 以 供 参 考 。 

提供 多 节 视 频 录像 : 本 书 提供 了 多 节 的 项 目 开发 视频 录像 ， 读 者 可 以 边 看 边 学 ， 

快速 提高 。 


[| 
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本 书 配套 资源 


| 本 书 提供 了 内 容 丰富 的 配套 资源 ， 包 括 自 学 视频 、 源 程序 、 素 材 ， 以 及 模块 库 、 案 例 
加 | 库 、 题 库 、 素 材 库 等 多 项 销 助 内 容 ， 读 者 朋友 可 以 通过 如 下 方式 获取 。 
~ | 第 1 种 方式 ; 

(1) 登录 wwwtup.com.cn， 在 网 页 右上 角 的 搜索 文本 框 中 输入 本 书 书 名 (注意 区 分 
| 大 小 写 和 留 出 空格 )， 或 者 输入 本 书 关键 字 ， 或 者 输入 本 书 ISBN 号 (注意 去 掉 ISBN 号 间 
| 隔 线 “-”)， 单 击 “搜索 ”按钮 。 
| 2) 找到 本 书后 单 击 超 链 接 ， 在 该 书 的 网 页 下 侧 单 击 “ 网 络 资源 ” 超 链接 ， 即 可 下 载 。 


第 2 种 方式 : 
| 访问 本 书 的 新 浪 微 博 PHPbook， 找 到 配套 资源 的 链接 地 址 进行 下 载 。 
| 本 书 约定 
项 目 使 用 方法 


| 用 户 在 学 习 本 书 过 程 中 ， 可 以 从 配套 资源 中 复制 程序 ， 去 掉 其 只 读 届 性 。 有 些 项 目 需 
| 要 使 用 相应 的 数据 库 或 第 三 方 资源 ， 此 类 程序 在 使 用 前 需要 进行 相应 配置 ， 详 细 使 用 方式 
| 可 参考 本 书 的 配套 资源 使 用 说 明 书 。 此 外 ， 如 果 用 户 直接 将 本 书 内 容 用 于 商业 用 途 ， 由 此 
| 产生 的 不 良 后 果 由 用 户 自己 承担 。 
| 回 部 分 项 目 只 给 出 关键 代码 

由 于 篇 幅 限制 , 书 中 有 些 模块 只 给 出 了 关键 代码 , 完整 代码 可 参见 配套 资源 项 目 程序 。 


读者 人 群 


本 书 非常 适合 以 下 人 员 阅 读 : 

从 事 PHP 编程 行业 的 开发 人 员 

有 一 定语 言 基础 ， 想 进一步 提高 技能 的 人 员 
大 中 专 院 校 的 老师 和 学 生 

即将 走 上 工作 岗位 的 大 学 毕业 生 

相关 培训 机 构 的 老师 和 学 员 

PHP 编程 爱好 者 


读者 服务 & 本 书 勘 误 


读者 在 使 用 本 书 过程 中 遇 到 的 所 有 问题 ， 均 可 通过 以 下 方式 联系 我 们 。 

1. 新 浪 微 博 : PHPbook。 

及 时 发 布 读者 答疑 、 本 书 勘误 、 配 套 资料 更 新 等 内 容 。 

2. 腾讯 QQ: 4006751066。 

3. 登录 网 站 : www.mingribook.com， 在 论坛 、 勘 误 发 布 、 读 者 纠 错 、 技 术 支 持 、 


a I 


| 


前 言 3 


读者 之 家 等 栏目 中 的 相关 模块 中 提问 、 留 言 或 查看 。 
本 书 插 文 


在 项 目 开 发 中 ， 总 是 会 有 一 些 开发 技巧 ， 笔 者 多 年 来 积累 了 许多 这 类 技巧 ， 对 于 这 些 医 靖 
技巧 ， 在 文中 以 “技巧 “注意 ”和 “说 明 ” 等 方式 为 读者 介绍 ， 这 样 也 可 以 提高 文档 的 
可 读 性 。 这 些小 栏目 说 明 如 下 。 

加 ”技巧 : 是 笔者 在 开发 中 积累 的 经 验 和 技巧 。 

回 ”注意 : 介绍 程序 开发 中 需要 留意 的 内 容 。 

说 明 : 针对 相应 项 目 而 言 的 、 一 些 读 者 需要 注意 的 内 容 。 


本 书 作者 


本 书 由 明日 科技 组 织 编写 ， 参 加 编写 的 有 潘 凯 华 、 李 慧 、 刘 欣 、 陈 丹 及 、 王 国 辉 、 张 ， 
振 坤 、 李 伟 、 沈 博 、 王 小 科 、 王 军 、 赵 会 东 、 董 大 永 、 尹 强 、 李 继 业 、 张 磊 、 赛 村 春 、 宋 | 
坤 、 刘 锐 宁 、 梁 水 、 李 伟 明 、 刘 彬 彬 、 安 剑 、 孙 秀 梅 、 巩 建华 、 房 大 伟 、 昌 双 、 刘 云 峰 、 ， 
李 钟 尉 、 卢 翰 、 梁 晓 岚 、 杨 丽 、 顾 丽 丽 、 刘 龄 龄 、 王 乐 乐 、 陈 英 、 李 贺 、 朱 晓 、 肖 筠 和 李 | 
移 和 刘 冠 男 等 。 | 

由 于 作者 水 平 有 限 ， 朴 漏 和 不 足 之 处 在 所 难免 ， 敬 请 广大 读者 朋友 批评 指正 。 
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图 书信 息 管理 系统 


( PHP+MySQL 实现 ) 
自学 视频 、 源 程序 : 配套 资源 \mAN1N 


图 书信 息 管 理 系 统 主要 用 于 对 公司 内 部 或 个 人 开发 的 图 书 进行 有 序 地 管 
理 ， 本 程序 记录 了 图 书 的 类 别 、 语 言 、 书 名 、 目 录 、 文 稿 路 径 和 程序 路 径 等 相 
关 信 息 ， 并 提供 了 多 种 搜索 条 件 ， 可 以 快速 、 有 效 地 查找 图 书信 息 。 

通过 阅读 本 章 ， 读 者 可 以 学 到 : 


WI 项 目 设计 思路 

了 数据 库 设计 

I 首页 页 面 设计 

WI 注册 模块 设计 

WI 登录 模块 设计 

I 图 书信 息 添 加 模块 设计 
I 图 书信 息 管理 模块 设计 
WI 图 书 搜索 模块 设计 


第 ] 章 图书 信息 管理 系统 (PHP+MJSQL 实现 ) 一 3 | 
1.1 项 目 设 计 思 路 | 
1.1.1 ”功能 阅 述 全 天 


图 书信 息 管 理 系统 主要 实现 对 图 书信 息 进行 分 类 、 分 语言 管理 , 并 对 图 书 的 基本 信息 、 革 43 
程序 、 文 稿 和 视频 文件 进行 管理 ， 以 便 用 户 可 以 快速 找到 需要 的 资源 。 在 本 系统 中 ， 用 户 
可 以 添加 、 修 改 和 删除 图 书信 息 。 | 


1.1.2 系统 预览 | 


图 书信 息 管理 系统 由 多 个 页 面 组 成 ， 下 面 列 出 几 个 典型 页 面 ， 其 他 页 面 可 参见 配套 资 
源 中 的 源 程序 。 
图 书信 息 管理 系统 主页 面 的 运行 效果 如 图 1.1 所 示 。 


ware 
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图 1.1 图 书信 息 管理 系统 主页 面 


图 书信 息 添加 页 面 的 运行 效果 如 图 1.2 所 示 。 | 
图 书 详细 信息 页 面 的 运行 效果 如 图 1.3 所 示 。 
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图 1.2 图 书信 息 添加 页 面 图 13 图 书 详细 信息 页 面 | 
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| 1.1.3 功能 结构 


图 书信 息 管 理 系统 的 功能 结构 如 图 1.4 所 示 。 


图 书信 息 管理 系统 


[end 
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图 1.4 图 书信 息 管理 系统 的 功能 结构 图 


| 11.4 文件 组 织 结构 
图 书信 息 管理 系统 中 使 用 的 根 目 录 文 件 夹 是 01， 其 中 包括 的 文件 架构 如 图 1.5 所 示 。 


1.5 图 书信 息 管理 系统 的 文件 架构 图 


| 

| 

| 

| 

| 

| En= 7 

| 日 - 留 com 

| 团 com php 一 一 一 一 一 一 一 数据 库 连 接 文件 

| 日 - 留 date 

| 局” db_book 一 一 一 一 一 一 一 数据 库 文件 

| 局 inages 一 一 一 一 一 一 一 一 一 图 片 文件 

| 团 ”define. php 一 一 一 一 一 一 一 一 图 书 详细 信息 页 

| 团 delete.phhp 一 图 书信 息 删 除 页 

| 团 enter.php 一 一 登录 表单 页 

| 团 ”enter_ok.php 一 一 一 一 一 一 一 登录 处 理 页 

| 一 团 indlexphp 一 首页 交 件 

| 团 insert.php 一 一 一 一 一 一 一 一 图 书 添加 表单 页 

| 国 insert_ok php 一 一 一 一 一 一 图 书 添加 处 理 页 

| 团 ”login php 一 一 一 一 一 一 一 一 一 注册 表单 页 

| 团 login_ok.php 一 一 一 一 一 一 一 注册 处 理 页 

| 团 ”more.php 一 一 一 一 一 一 一 一 图 书信 息 分 类 显示 页 
| 团 select.php 一 一 一 一 一 一 一 一 图 书 搜索 页 

| 团 《stop.php 一 一 一 一 一 一 一 一 退出 页 

| 团 “ update php 一 一 一 一 一 一 一 一 图 书信 息 管理 页 

| 国 ”update_ok php 一 一 一 一 一 一 一 图 书信 息 修改 表单 页 
| 国 update_ok_ok. php 一 一 一 一 图 书信 息 修改 处 理 页 
| 

| 

| 


4. 
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1.2 数据 库 设 计 


1.2.1 数据库 设计 结构 人 
图 书信 息 管 理 系统 中 ， 采 用 的 是 MySQL 数据 库 ， 主 要 用 来 存储 图 书信 息 。 这 里 将 数 
据 库 命名 为 tb book， 其 中 包含 的 数据 表 如 图 1.6 所 示 。 ! 


中 服务 器 : localhost 〉 区 数据 库 : db_book | 
共振 构 ,于 SOL 万 掉 过 所 查 鹿苑 呈 出 一 Imporl 区 措 作 所 权 限 ” 演 副 除 | 


表 换 作 记录 小便。 类 型 整理 表明 1 
th_book 国共 加 末 围 X 13 MySAM ure_general_cl ETT ! 
tm 辣 队 回头 硬 X 2 MWSAM uile_general_cl 。 sm 人 | 
也 proam 图 熙 四 广 国 X 6 NYSAM ua_generalLecl 图 HS ! 
Wt 可 回 尼 加 X 6 NMYSAM Ute general .cl Enegk | 

4T 表 Si 计 27 MASAM wt8_general_cl | 


图 1.6 数据 库 结构 | 
1.2.2 ”数据 表 设计 结构 | 
数据 表 设 计 是 一 个 非常 关键 的 环节 ， 下 面 对 系 统 中 的 数据 表 结构 进行 分 析 。 

1， 图 书信 息 表 (tb_book) 


图 书信 息 表 主 要 用 于 存储 图 书信 息 ， 数 据 表 字段 设计 如 表 1.1 所 示 。 
表 1.1 图 书信 息 表 (tb_book) 设计 


字段 类 型 | 额外 | 说 。 明 | 
id int (10) 信息 id | 
sort varchar (100) | | 图 书 类 别 | 
talk varchar (100) | | 图 书 语言 | 
books varchar (100) | | 书 名 | 

nopsis varchar (100) | | 简介 | 
catalog varchar (100) | | 目录 | 
bookpath varchar (100) | | 图 书 文稿 路 径 | 
programpath varchar (100) | | 图 书 程序 路 径 | 
videopath varchar (100) | | 视频 文件 路 径 | 
date date | 录入 日 其 | 


2， 图 书 类 别 表 (tb_sort) 
图 书 类 别 表 主要 用 于 存储 图 书 类 别 信息 ， 数 据 表 字段 设计 如 表 1.2 所 示 。 
表 1.2 图 书 类 别 表 (tb_sort) 设计 


字 段 类 型 额 外 说 阴 
id | int (10) auto_increment 类 别 id | 
sort varchar (40) 类 别名 称 | 


.5。 要 


3. 图 书 语言 表 (tb _program ) 
| 图 书 语言 表 主 要 用 于 存储 图 书 语言 ， 数 据 表 字段 设计 如 表 1.3 所 示 。 
表 1.3 图 书 语言 表 (tb_program) 设计 


类 型 
int (10) 
varchar (40) 


4. 会 员 信 息 表 (tb login ) 
| 会 员 信息 表 主 要 用 于 存储 会 员 的 基本 信息 ， 数 据 表 字段 设计 如 表 1.4 所 示 。 
| 表 1.4 会 员 信息 表 (tb_login) 设计 


| 字段 类 型 额 外 说 了 明 
| id int (10) auto_increment 会 员 id 

| User varchar (40) 会 员 用 户 名 
| 


pwd Varchar (40) [| 会 员 密 码 
section varchar (40) | | 所 在 部 门 
name varchar (40) | | 真实 姓名 


1.2.3 ”连接 数据 库 


| 由 于 系统 大 部 分 页 面 都 需要 使 用 数据 库 ， 如 果 每 页 都 编写 相同 的 数据 库 连 接 代码 ， 会 
| 显得 十 分 烦琐 ， 所 以 本 系统 将 数据 库 连 接 代码 单 独 存 入 一 个 PHP 文件 conn.php 中 ， 在 需 


| 要 与 数据 库 连 接 的 页 面 中 ， 使 用 包含 函数 包含 该 文件 即 可 ， 代 码 如 下 : 
01 <?php 
| 02 ”Sconn=mysql_connect("localhost"."root"."111"):// 连 接 数据 库 服务 器 
| 03 mysql select db("db_book".$conn):; // 连 接 数据 库 
| 04 mysql query("set names utf8"); // 对 数据 库 中 编码 格式 进行 转换 ， 避 免 出 现 中 
， 文 乱码 的 问题 
05 > 


13 首页 设计 
1.3.1 首页 页 面 概述 
| 运行 程序 ， 进 入 图 书信 息 管理 系统 首页 ， 如 图 1.7 所 示 。 在 首页 中 ， 对 图 书信 息 按 语 


| 言 进行 了 分 类 显示 ， 单 击 图 书 书 名 可 查看 图 书 的 详细 信息 ， 还 可 以 进行 搜索 图 书信 息 等 操 
| 作 。 其 中 图 书信 息 添 加 和 图 书信 息 管 理 需要 登录 后 才 可 以 操作 。 


第 工 章 图书 信息 管理 系统 (PIHPHISQLC 实现 ) | T 


图 1.7 图 书信 息 管理 系统 首页 运行 结果 | 
1.3.2 ”获取 超 链 接 传递 的 数据 


本 系统 首页 页 面 中 ， 查 看 图 书 详细 信息 及 更 多 图 书信 息 分 别 使 用 了 超 链接 传 值 技术 。 | 
查看 图 书 详细 信息 时 ， 主 要 通过 超 链接 传递 图 书 的 id 序号 ; 查看 更 多 图 书信 息 时 ， 主 要 通 | 
过 超 链 接 传递 图 书 的 语言 。 关 键 代 码 如 下 : | 

(1) 通过 超 链接 传递 图 书 的 id 序号: | 

<a href="define.php?id=<?php echo $array1["id"]:?>"><?php echo $arrayl1[books']:?></a> | 

(2) 通过 超 链接 传递 图 书 的 语言 

<a target="_blank" href="more.php?talk1=<?php echo $talk1:?>"> 更 多 &lt:&lt:</a> 


1. 通过 超 链接 传递 值 | 
定义 超 链接 使 用 <a> 标 记 ， 其 语法 格式 如 下 : 
<a href-URL name=name target=targef> 链 接 文字 </a> 


a 标记 的 属性 如 下 : 
@ href 属性 : 指定 所 链接 文件 的 URL 路径。 该 路 径 可 以 是 相对 路 径 ， 也 可 以 是 绝对 | 
路 径 。 
@ name 属性 : 指定 页 面 的 锚 点 名 称 ， 如 果 需 要 链接 到 对 应 的 锚 点 位 置 ， 需 要 在 锚 点 
名 称 前 添加 一 个 “#” 字 符 。 
@ target 属性 : 指定 要 打开 的 链接 所 使 用 的 浏览 器 窗口 名 称 ， 可 以 使 用 自 定义 的 窗口 
名 称 ， 也 可 以 使 用 下 面 4 个 内 置 的 窗口 名 称 ， 其 中 前 两 个 比较 常用 。 


。7。 L_ 


Pr 人 Bi 项 目 业 例 分 析 
六 


_self: 在 当前 窗口 中 打开 链接 文件 ， 是 默认 值 。 

| _blank: 开启 一 个 新 的 窗口 打开 链接 文件 。 

_parent: 在 父 级 窗口 中 打开 文件 ， 常 用 于 框架 页 面 。 
_top: 在 顶层 窗口 中 打开 文件 ， 常 用 于 框架 页 面 。 


Ee 2. 通过 $_GET[] 方 法 获取 超 链 接 传 递 的 数据 


获取 超 链接 传递 的 数据 ， 需 要 使 用 $_GETD 方 法 。 
| (1) 获取 图 书 id 序 号 的 关键 代码 如 下 : 


01 ifisset($_GET[id]){ // 济 断 图 书 id 是 否 存在 
02 $id=$ GET[id]; /为 图 书记 定义 变量 名 称 
| 03 $selectl=mysql query("select * from tb book where id=-'Sid'",Sconn); /查询 图 书信 息 
| 04 $arrayl=mysql fetch array($select]): /获取 查询 结果 
05 } 
(2) 获取 图 书 语言 的 关键 代码 如 下 : 
01 iflisset($_GET['talk1]){ 1/ 判断 图 书 语言 信息 是 否 存在 
| 02 S$talk=$ GET['alkl’]: // 为 图 书 语言 信息 定义 变量 名 称 
03 $selectl=mysql_query("select * from tb_book where talk='$talk"",Sconn);// 查 询 图 书信 息 
>>> 


1.3.3 首页 页 面 实现 过 程 
首页 页 面 的 设计 效果 如 图 1.8 所 示 。 


1.8 首页 页 面 设计 效果 


| 具体 实现 过 程 如 下 : 
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(1) 首页 页 面 主要 包括 程序 导航 菜单 、 搜 索 及 最 新 图 书信 息 列表 等 功能 ， 其 中 ， 导 
航 菜单 部 分 包括 输出 首页 、 图 书信 息 添加 和 图 书信 息 管理 的 超 链 接 ， 关 键 代码 如 下 : 
代码 位 置 : 配套 资源 \mr\0l\index.php 


01 <td width="800" height="29" valign="bottom" background="images/book 04.gif'><table 
width="800"> 


02 <tr> 
03 <td width="47"><div align="center"><a href="index.php"> 首 页 </a></div></td> 
04 <td width="87"> <div align="center"><a href="insert.php"> 图 书信 息 添 加 </a> 
05 <a href="update.php"></a></div></td> 

06 <td width="84"><div align="center"><a hre 人 ="update.php'"> 图 书信 息 管理 </a></div></td> 
07 <2php 

08 if(isset($_SESSION['user']){ // 判 断 session 是 否 存 在 

09 ?> 

10 <td width="512"><div align= "right"><a href="stop.php"> 

11 </a> 欢 迎 您 : <?php echo S_ SESSION['user'];?></div></td> 

12 <td width="46"><div align="right"><a href="stop.php"> 退 出 </a></div></td> 

13 <?php 

14 } 

15 ?> 

16 </tr> 

ji </table></td> 


(2) 在 搜索 部 分 创建 form 表单 ， 提 交 查 询 的 关键 字 ， 并 且 将 关键 字 提交 到 select.php 
文件 中 进行 处 理 。 图 书 查 询 form 表单 创建 的 关键 代码 如 下 详细 代码 请 参见 1.8 节 ): 
代码 位 置 ， 配套 资源 \mr\0l\index.php 


01 <td width="800" height="30" align="center' bgcolor="#ECC647"> 

02 <table width="758" height="23" border="0" cellpadding="0" cellspacing="0"> 

03 <u> 

04 <td width="206"><div align="right" class="STYLE2"> 图 书 搜索 ;</div></td> 

05 <td width="159"><table> 

06 <form id="list" name="list" method="post"> 

07 <t> 

08 <td width="125" align="left" valign="middle"><select name="select" onchange= "javascript: | 
list.submitO "> 

09 <option value="" selected="selected"> 请 选择 </option> 

10 <option value="Famous_Id"> 类 别 </option> 

11 <option value="Famous_Ids"> 语 言 </option> 

12 <option value="boo_name"> 书 名 </option> 

13 <option value="jianjie"> 简 介 </option> 

14 <option value="mulu"> 目 录 </option> 

15 </select></td> 

16 </t> 

Fh </form> 
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</table> 
</td> 
<td width="295"> 
<table width="254" height="29" border="0" cellspacing="0" cellpadding="0"> 


22 <form id="forml" name="forml" method="post" action="select.php" onKeyPress="press(3)" 


onKeyUp="up(3)"> 
23 
24 
25 
26 
27 
28 
29 
30 
3 
32 
33 
34 
35 


| 
Sarrl['talk']:?></option> 


41 
42 


45 
$arrl['talk]:2></option> 
46 
47 
48 
49 
50 
51 


<t> 
<td width="110"><select name="select2"> 
<option selected="selected"> 请 选择 </option> 


<2php 
ifisset($_ POST[select]){ // 判 断 搜索 条 件 是 否 存在 
$select=$_POST['select']: /为 搜索 条 件 定义 变量 名 
if(Sselect 一 "Famous Id"){ /判断 搜索 条 件 是 否 为 “类 别 ” 


$sel=mysql_query("select * from tb_sort",$conn); /查询 图 书 类 别 
while($arr=mysql _fetch_array($seD){ /循环 输出 图 书 类 别 信息 
?> 
<option value="<?php echo Samfsort]?>"><?php echo Sanfsort].?></option> 
<?php 
上 
jelse if(Sselect 一 "Famous Ids"){ /判断 搜索 条 件 是 否 为 “语言 
$sell=mysql_query("select * from tb_program".$conn): /查询 图 书 语言 
while($arrl=mysql_fetch_array($sel1)){ /循环 输出 图 书 语言 信息 
?> 
<option value="<?php echo $arrl['alk]:?>”selected="selected"><?php echo 


<?php 
}else{ 
?> 


<option value="<?php echo $arrl['talk]:?>”selected="selected"><?php echo 


<?php 
) 


> 
</select> 
<td> 


52 <td width="144"><input type="image" name="imageField" src="images/book 05 02.gif' onclick= 


"return fetch0;" /></td> 


53 </tr> 

54 </form> 

55 </table> 

56 <ltd> 

= <td width="98">&nbsp:</td> 
58 </tr> 

59 </table></td> 
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(3) 最 新 图 书信 息 显示 ， 可 以 查询 出 每 类 图 书 中 最 新 的 两 条 数据 ， 并 且 通 过 while 语 
句 循环 输出 查询 结果 ， 其 关键 代码 如 下 : 


代码 位 置 : 配套 资源 \mr\0l\index.php 


01 <?php 
02 include("conn/conn.php"); 
03 ”// 查 询 PHP 类 最 新 图 书信 息 
04 
05 ”// 查 询 C 类 最 新 图 书信 息 
06 $select2=mysql 
07 ”// 查 询 .net 类 最 新 图 书信 息 
08 
09 ”// 查 询 JAVA 类 最 新 图 书信 息 
10 
11 ”// 查 询 VB 类 最 新 图 书信 息 
12 $selects=mysql ¢ 
13 ”// 查 询 其 他 类 最 新 图 书信 息 
14 
15 $select=mysql query("select * from tb book".$conn): 
16 S$array=mysql fetch array($select); 
17 ?> 
18 <tdheight="100" align="center" valign="baseline"> 
19 
20 <tr> 
2 
22 </t> 
23 <?php 
24 
pa Stalk1=Sarray1['talk’]; 
26 ?> 
27X <tr> 
28 
29 <td width="248" align="left"> 
30 
[books]:?></a></td> 
31 </tr> 
32 。 <?php 
3 
34 > 
35 </table> 
36 
&lt&lt:<la><lp></td> 
37 /省 略 部 分 代码 
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SS 


SA 


$selectl=mysql_query("select * from 也 book where talk=PHP' order by id DESC limit 2",$conn); 


query("select * from tb book where talk=C" order by id DESC limit 2",$conn): 


$select3=mysql_query("select * from tb book where talk= net order by id DESC limit 2",$conn); 


$select4=mysql_query("select * from tb book where talk=:JAVA' order by id DESC limit 2",$conn); 


query("select * from tb_book where talk=VB’ order by id DESC limit 2",$conn); 


$select6=mysql_query("select * ftom tb_book where talk=' 其 他 ' order by id DESC limit 2",$conn); 


// 查 询 所 有 图 书信 息 ， 供 搜索 使 用 
// 获 取 所 有 图 书信 息 


<table width="281" height="44" border="0" cellpadding="0" cellspacing="0"> 


<td height="19" colspan="2"><div align="center" class="STYLE3">PHP </div></td> 


while(Sarrayl=mysql_fetch_array(SselectD){ ”// 循 环 输出 图 书信 息 


<td width="21" height="17">&nbsp:</td> 


<a href="define.php?id=<?php echo $arrayl['id"]:?>"><?php echo S$arrayl 


<p align="right"><a target="_ blank" href-"more.php?talk1-<?php echo Stalkl;?>"> 更 多 
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1.4 注册 模块 设计 


生 1.4.1 注册 模块 概述 
下 功能 主要 用 于 为 用 户 获取 登录 用 户 名 和 密码 。 在 首页 中 单 击 “注册 ” 超 链接 ， 即 
| 可 进入 注册 页 面 ， 在 注册 页 面 中 填写 用 户 各、 密码 、 部 门 及 真实 姓名 后 ， 单 击 “ 注 册 ” 按 
| 乌 妈 可 完成 注册 操作 。 注 册 模块 的 运行 效果 如 图 19 所 示 。 


图 1.9 注册 模块 运行 效果 
1.4.2 ”注册 模块 实现 过 程 
注册 模块 的 设计 效果 如 图 1.10 所 示 。 


3 GD 


图 1.10 注册 模块 设计 效果 
具体 实现 过 程 如 下 : 
| (1) 用 户 注册 模块 主要 由 表单 页 面 (login.php) 及 数据 信息 处 理 页 (login_ok.php) 
| 组 成 。 在 表单 页 login.php 中 ,创建 form 表单 ， 提 交 用 户 注册 信息 ， 并 且 将 数据 提交 到 
| login_ok.php 文件 中 ， 其 关键 代码 如 下 : 
| 代码 位 置 配套 资源 \mr\01\login.php 


| 01 <form id="form1" name="forml" method="post" action="login ok.php"> 
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02 

Oo 
03 
04 


05 
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NS 


<table width="1000" height="467" border="0" align="center" cellpaddine="0" cellspacing= 


<tr> 
<td colspan—"7"><img stc="images/enter 01.gif' width="1000" height="174" alt=" /></td> 
</t> 
<tr> 
<td rowspan="2"><img src- ”images/enter 02.gif' width="145" height="213" alt=" /></td> 
<td background="images/enter 03.gif > 
<table width="371" height="147" border="0" cellpadding="0" cellspacing="0"> 
<t> 
<td width="87"> 用 户 名 : </td> 
<td width="284"><input name="user" type="text" id="user" /></td> 
</t> 
<tr> 
<td> 密 码 : </td> 
<td><input name="pwd" type="password" id="pwd" size="22" /></td> 
</t> 
<t> 
<td> 部 门 : </td> 
<td><input name="section" type="text" id="section" /></td> 
</t> 
<tr> 
<td> 真 实 姓 名 : </td> 
<td><input name="name" type="text" id="name" /></td> 
</t> 
</table></td> 
<td rowspan="2"><img strc="images/enter 04.gif" width="149" height="213" alt="" /></td> 
</> 
<tr> 
<td><img src="images/enter 05.gif" width="257" height="27" alt="" /></td> 
<td width="75" height="27"> 
<input type="image" name="imageField" src="images/enter 06.gif" /></td> 
<td><img src="images/enter 07.gif" width="54" height="27" alt="" /></td> 
<td width="73" height="27"> 
<input type—"image" src= "imagesenter 08.gif' onclick="form.resetO; retum false;" /></td> 
<td><img src="images/enter_09.gif" width="247" height="27" alt="" /></td> 
</t> 
<tr> 
<td colspan="7"><img src= "images/enter_ 10.8if' width="1000" height="80" alt="" /></td> 
</tr> 
</table> 


</form> 


(2) 用 户 单 击 “ 注 册 ” 按 钮 后 ， 将 数据 提交 到 数据 处 理 页 login_ok.php 中 ， 对 提交 的 


数据 进行 验证 ， 如 果 正 确 ， 则 将 数据 添加 到 指定 的 数据 表 中 ， 提 示 用 户 注 册 成 功 ， 否 则 ， 
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| 返回 用 户 注 册页 面 。login_okphp 的 代码 如 下 : 


代码 位 置 ， 配套 资源 \mr\01\login_ok.php 

01 <?php 

02 header("content-type:text/html:charset=utf-8"): // 设 置 页 面 编码 

03 include("conn/conn.php"); // 包 含 数据 库 连 接 文 件 

04 ”// 判 断 用 户 名 、 密 码 等 信息 是 否 存在 

05 iflisset($ POST[mser]) and isset($ POST[pwd]) and isset($ POST['section]) and isset($_ 
| POST[nameJ){ 

06 // 判 断 用 户 名 、 密 码 等 信息 是 否 不 为 空 
| 07 if($ POST['user']!=null and $ POST[pwd]'=null and $ POST[section]'=null and 
| $ POST['name]!=nul){ 
| 08 /查询 数据 库 中 是 否 存在 该 用 户 名 

09 Sselect=mysql query("select * from tb login Where user="".$ POST["user']. 
,Sconn); 

10 if(mysql num rows(Sselecb 一 0){ // 判 断 查询 结果 是 硅 为 0 

i /如 果 用 户 名 不 存在 ， 则 执行 添加 操作 

12 Sinsert=mysql_query("insert into tb_login(user.pwd.section.name) 

13 values(".$ POST['user].".".$ POST['pwd'].",".$ POST['section']." ".$_ POST['name’].")", 

$conn); 
14 if($insert) { // 判 断 添 加 操作 是 否 执 行 成 功 
15 echo "<scriptf>alert( 恭 喜 您 ! 注册 成 功 ! ):window.location_ href-'enterphp'</script>": 
// 输 出 注册 成 功 提示 
16 }else{ 
7 echo "<script>alert( 注 册 失 败 ! ):windowlocation hre 人 login.php'</script>": 
/否则 输出 注册 失败 提示 

18 可 

19 }else{ 

20 // 输 出 用 户 名 已 存在 提示 

21 echo "<script>alert( 用 户 名 已 存在 ， 请 重新 输入 ! ');window.location.hre 人 = 

"login.php'</script>"; 

22 } 

23 }else{ 

24 // 输 出 请 填写 完整 信息 提示 

25 echo "<script>alert( 请 填写 完整 注册 信息 ! ):windowlocation href-login php </scrip>"; 

26 

27 有 六 

28 > 


1.5 登录 模块 设计 


1.5.1 登录 模块 概述 
注册 成 功 后 , 用 户 即 可 使 用 注册 的 用 户 名 和 密码 进行 登录 。 单 击 首页 页 面 中 的 “登录 ” 
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| 
国 链接 ， 进 入 登录 页 面 ， 输 入 正确 的 用 户 名 和 密码 ， 单 击 “ 登 录 ” 按 钮 ， 即 可 成 功 登 录 ， | 
户 登 录 成 功 后 可 以 添加 和 管理 图 书信 息 。 用 户 登录 模块 的 运行 效果 如 图 1.11 所 示 。 | 


图 1.11 用 户 登录 模块 运行 效果 | 
1.5.2 ”登录 模块 实现 过 程 
登录 模块 的 设计 效果 如 图 1.12 所 示 。 


图 1.12 登录 模块 的 设计 效果 


具体 实现 过 程 如 下 : 

(1) 用 户 登 录 模 块 主要 由 表单 设计 页 (enterphp) 及 数据 信息 处 理 页 (enter_ok.php) 
两 个 页 面 组 成 。 在 enterphp 页 中 ， 创 建 form 表单 提交 用 户 登录 的 用 户 名 和 密码 。 其 关键 | 
代码 如 下 : | 

代码 位 置 ， 配套 资源 \mr\0l\enter.php | 


01 <form id="forml" name="forml" method="post" action="enter_ok.php"> | 


02 <input name="user" type="text" id="user" size="20" /> | 

03 <input name="pwd" type="password" id="pwd" size="22" /> 

04 <input type="image" name="imageField" src="images/login_08.gif" /> | 

05 <input type="image" name="imageField2" src="images/login 10.gif' onclick="form. | 
resetO; return false;" /> | 

06 -</form> | 


(2) 当 用 户 单 击 “ 登 录 ” 按 钮 后 ， 将 在 数据 信息 处 理 页 中 对 提交 的 数据 进行 验证 ， 如 果 
正确 ， 则 提示 用 户 登 录 成 功 ， 和 否则 ， 返 回 用 户 登录 页 面 。 用 户 登 录 数 据 处 理 页 的 代码 如 下 : 


| 
代码 位 置 ， 配套 资源 \mr\0l\enter_ok.php | 
| 


01 <?php 
02 session startO: 1/ 调用 session_start0 函 数 ， 声 明 session 
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1.6 图 书信 息 添 加 模块 设计 


| 1.6.1 图 书信 息 添加 模块 概述 
只 有 登录 成 功 的 用 户 ， 才 可 以 进入 图 书信 息 添 加 模块 。 在 首页 导航 菜单 中 ， 单 击 “ 图 


| 

| 
03 header("content-type:text/html:charset=utf-8"): // 设 置 文 件 编码 

| 04 include("conn/conn.php"): // 包 含 数据 库 连 接 文件 

| 05 iflisset($ POST[muser]) and isset($ POST['pwd']){ 1/ 判断 用 户 名 和 密码 是 否 存在 
06 if($_POST['user]!=null and $ POST['pwd']!=nulD){ // 判 断 用 户 名 和 密码 是 否 为 空 

优 站 07 S$select=mysql query("'select * from tb login where user=".$ POST['user]." and 
| 08 pwd="".$ POST['pwa'].""",Sconn); // 查 询 用 户 名 和 密码 
Noe | 09 if(mysql num rows(Sselecb 一 Df // 判 断 查询 结果 是 否 为 1 

| 10 echo "<script>alert( 登 录 成 功 !"):window.location href='index.php':</script>"; 

| // 登 录 成 功 提示 

| Dn $_SESSION["user']=$_POST['user"]; // 定 义 session 变量 

| 12 }else{ 

| 13 // 输 出 用 户 名 和 密码 不 正确 提示 
14 echo "<script>alert( 用户 名 和 密码 不 正确 ! ");window.location.hre 仁 

‘enter.php';</script>"; 

| 15 } 

| 16 yelse{ 

| 17 // 输 出 请 输入 用 户 名 和 密码 提示 

| 18 echo "<script>alert( 请 输入 用 户 名 和 密码 ! );window.location.href='enter php'; </script>"; 
19 } 

| 2000 

| DIE 

| 

| 

| 

| 

| 

| 


| 书信 息 添加 ” 超 链接 ， 即 可 进入 到 图 书信 息 添加 页 面 ， 运 行 效果 如 图 1.13 所 示 。 填 写 完整 
| 的 图 书信 息 后 ， 单 击 “ 提 交 ” 按 钮 ， 即 可 完成 图 书信 息 添加 操作 。 


5: [EE 
EB [可 寺 习 

WE: FE 可 

i: FE FS GE 人 
3: 1 | 
EE 

程序 路 怪 : 


1.13 图 书信 息 添 加 模块 运行 效果 


了 。16。 
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1.6.2 在 下 拉 菜 单 中 显示 数据 表 某 列 的 字段 值 | 


图 书信 息 添加 模块 中 主要 通过 下 拉 菜 单 显 示 图 书 类 别 及 语言 信息 。 首先， 创建 下 拉 列 | 
表 框 。 然 后 ， 使 用 select 语句 查询 数据 表 中 的 数据 。 最 后 ， 将 查询 到 的 sort 字段 的 值 作为 | 依 内 
下 拉 列 表 框 的 值 ， 使 用 while0 语 句 循环 输出 ， 其 关键 代码 如 下 : hs 


代码 位 置 : 配套 资源 \mr\0l\insert.php | Note 
01 <?php | 
02 $selectl=mysql query("select * from tb _sort".$conn): // 查 询 图 书 类 别 | 
03 <td><div align="left"> 类 别 : </div></td> | 
04 <td><div align= "left"> | 
05 <select name="sort" id="sort"> | 
06 <?php | 
07 while(Sarrayl=mysql fetch array(Sselect1){ /循环 输出 类 别 信息 | 
08 ?> ! 
09 <option value="<?php echo Sarrayl['sort];?>"><?php echo Sarrayl | 
['sort'];?></option> ! 
10 
11 | 
i | 
13 </select> | 
14 </div></td> 
15 ?> 


| 
说 明 ，; 
上 面 代码 实现 的 是 显示 图 书 类 别 ， 显 示 图 书 语言 的 实现 方法 同上 ， 这 里 不 再 将 过 | 


(1) select 查询 语句 
select 查询 语句 的 语法 如 下 : 
$result=mysql_query("select * 位 om tb_user where name="mr", $conn); 

其 中 , mysql_query0 函 数 执 行 对 数据 库 操 作 的 SQL 语句 ; $conn 为 服务 器 的 连接 标识 。 
(2) while0 循 环 语句 | 
while0 循 环 语句 的 作用 是 反复 执行 某 一 项 操作 ， 是 循环 控制 语句 中 最 简单 且 最 常用 的 | 
-个 。while() 循 环 语句 对 表达 式 的 值 进行 判断 ， 当 表达 式 为 非 0 值 时 ， 执 行 while0 语 句 中 
的 内 嵌 语 句 ; 当 表达 式 的 值 为 0 时, 则 不 执行 while0 语 句 中 的 内 嵌 语 句 。 该 语句 的 特点 是 : 
先 判断 表达 式 ， 后 执行 语句 。while 循环 控制 语句 的 操作 流程 如 图 1.14 所 示 。 | 


图 1.14 ”while0 循 环 控制 语句 的 操作 流程 | 
17. ~ 


~ 可 Bi 项 目 业 例 分 析 


| while (expD{ 让 
| statement' 先 判断 条 件 ， 当 条 件 满足 时 执行 语句 块 ， 否 则 
缚 站 | 不 向 下 执行 
} 


只 要 while 表达 式 expr 的 值 为 TRUE, 就 重复 执行 谋 套 中 的 statement 语句 , 如 果 while 
| 表达 式 的 值 一 开始 就 是 FALSE， 则 循环 语句 一 次 也 不 执行 。 


1.6.3 ”图书 信息 添加 模块 实现 过 程 
图 书信 息 添 加 模块 的 设计 效果 如 图 1.15 所 示 。 


图 1.15 图 书信 息 添加 模块 设计 效果 


| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 具体 实现 过 程 如 下 : 
| (1) 图 书信 息 添加 模块 主要 由 表单 设计 页 (insertphp) 和 数据 处 理 页 (insert_ok.php) 
组成， 表单 设计 页 的 关键 代码 如 下 
| 代码 位 置 ， 配套 资源 \mr\0l\insert.php 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
j 


01 <form action="insert ok.php" method="post" enctype="multipart/form-data" name="form2" 


id="form2"> 
02 <p>&nbsp:</p> 
03 <table width="527" height="321" border="0" cellpadding="0" cellspacing="0"> 
04 <tr> 
05 <td width="112"><div align="left"> 书 名 : </div></td> 
06 <td width="415"><div align="left"> 
07 <input name="books" type="text" id="books" size="50" /> 
08 </div></td> 
09 </tr> 
10 <tr> 
各 <td><div align="left"> 类 别 : </div></td> 
1 <td><div align="left"> 
13 <select name="sort" id="sort"> 
14 <2php 
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15 while(Sarrayl=mysql fetch array(S$selectD){ 1/ 循 环 输出 类 别 信息 | 
16 > | 
17 <option value="<?php echo $arrayl['sort]:?>"><?php echo $array1['sort]:?> | 
</option> | 
18 <2php | 
19 ) | 
20 ee 
2 </select> | 
22 </div></td> | 
23 </tr> | 
24 <t> | 
25 <td><div align="left"> 语 言 :</div></td> | 
26 <td><div align="left"> | 
27 <select name="talk" id= "talk"> | 
28 <2php | 
29 while(Sarray2-mysql_fetch_array(Sselect2)){ /循环 输出 语言 信息 | 
30 2> | 
31 <option value="<?php echo $array2['talk']:?>"><?php echo $array2['talk]:?> | 
</option> | 
32 <2php | 
33 | | 
34 > | 
35 </select> | 
36 <ldiv></td> | 
37 </a> | 
38 <tr> | 
29 <td><div align="left"> 简 介 : </div></td> | 
40 <td><div align="left"> | 
41 <input name="synopsis" type="text" id="synopsis" size="50" /> | 
42 </div></td> | 
43 </t> | 
44 <!-- 省 略 部 分 代码 --> | 
45 <t> | 
46 <td colspan="2"><div align="center"> | 
47 <input type="submit" name="Submit" value=" 提 交 " /> 
48 <input type="submit" name="Submit2" value=" 取 消 " /> 
49 </div></td> 
50 </tr> 
51 </table> 
1 </form> 


〈2) 当 用 户 单 击 “ 提 交 ” 按 钮 后 ， 在 数据 处 理 页 获取 表单 提交 数据 ， 将 其 添加 到 指 
定 的 数据 表 中 ， 关 键 代码 如 下 : 
代码 位 置 : 配套 资源 \mr\0l\insert_ok.php 


0 <?php 
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| 02 header("content-type:text/html:charset-utf-8"): // 设 置 文件 编码 
| 03 include("conn/conn php"): // 包 含 数据 库 连 接 文件 
| 04 iftisset($_POST['Submit]) and $ POST['Submit]==" 提 交 "){ // 判 断 “ 提 交 ” 按 钮 是 否 存在 
| 05 $sort-$_ POST['sort]: /定义 类 别 变量 
食 人 | 06 Stalk=$ POST[Malk]: /定义 语言 变量 
| 07 $books=$_ POST['books']: // 定 义 书 名 变量 
08 $synopsis=$ POST['synopsis']: /定义 简介 变量 
| 09 Scatalog=$_POST['catalog’]: // 定 义 目录 变量 
| 10 Scata=str_replace(chr(13)."<br>",$catalog): // 保 留 目录 中 的 换行 符 
| 11 Sbookpath=$_POST['bookpath']: // 定 义 文稿 路 径 变量 
| 12 S$programpath=$_POST['programpath']: // 定 义 程序 路 径 变量 
| 把 Svideopath=$_POST['videopath']: // 定 义 录像 路 径 变 量 
| 14 $date=date('Y-m-d’); // 定 义 时 间 变 量 
15 /执行 添加 操作 


16 Sinsert=mysql query("insert into tb book(sort,talk,books,synopsis,catalog,bookpath, 
programpath, videopath,date) 

17 values('$sort','Stalk','Sbooks','Ssynopsis','Scata','Sbookpath','Sprogrampath','Svideopath', 
"$date)",Sconn); 


18 这 $inserb{ // 济 断 添加 语句 是 否 执行 成 功 
| 19 echo "<script>alert(' 添 加 成 功 ! "):window.location.href='index.php'</script>"; 
| // 输 出 添加 成 功 提示 
| 20 jelse{ 
| 21 echo "<script>alert( 添 加 失败 ! "):window.location.href='insert.php'</script>"; 
| // 输 出 添加 失败 提示 
| 22 4 
| 2 
24 > 


说 明 : 
在 图 书信 息 添加 模块 中 ， 对 于 图 书 的 文稿 、 程 序 和 录像 存储 的 都 是 指定 的 路 径 ， 并 没 
有 完成 具体 文件 的 上 传 操作 。 这 些 内 容 需要 手动 存储 到 服务 器 的 对 应 文件 夹 下 。 


1.7 图书 信息 管理 模块 设计 


1.7.1 图 书信 息 管理 模块 概述 


| 用 户 成 功 登 录 后 , 才 可 以 进入 图 书信 息 管理 模块 。 在 导航 菜单 中 单 击 “ 图 书信 息 管理 ” 
| 超 链 接 ， 即 可 进入 到 图 书信 息 管理 页 面 中 ,运行 效果 如 图 1.16 所 示 。 在 图 书信 息 管理 页 面 
中 ， 可 以 查看 图 书 的 详细 信息 ， 修 改 及 删除 图 书信 息 。 
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1.16 图 书信 息 管理 页 面 运 行 效果 


1.7.2 分 页 技术 


在 图 书信 息 管理 模块 中 对 图 书信 息 进行 了 分 页 显示 ， 每 页 显示 10 条 记录 ， 当 总 记录 
数 超过 10 条 时 自动 分 页 ， 并 显示 “下 一 页 ”、“ 尾 页 ” 超 链接 ， 其 关键 代码 如 下 : 
代码 位 置 : 配套 资源 \mm\01\update.php 


01 


20 
21 
count;?> 页 


if Gisset($_GET['page ]){ // 判 断 分 页 变量 是 否 存在 
$page=$_ GET['page']: // 如 果 存 在 ， 将 分 页 变量 值 赋 给 指定 的 变量 
}else{ 
$page=1: /如 果 不 存在 ， 则 设置 变量 初始 值 为 1 
} 
> 
<2php 
if($page){ 
Spage_size=10; // 每 页 显示 10 条 记录 
Squery="select * from tb_book"; // 定 义 查询 语句 
Sresult=mysql_query($query): // 执 行 查询 操作 
Smessage_count=mysql_ num rows(Sresult); // 获 取 查 询 总 数 
Spage_count=ceil(Smessage_count/Spage size); // 获 取 总 的 页 数 
Soffset=(Spage-1)*Spage_size; // 计 算 每 页 的 起 始 记 录 数 


/定义 SQL 语句 ， 查 询 当 前 页 显示 的 记录 
$query="select * from tb_book where id order by id desc limit Soffset, Spage_size"; 
Sresult=mysql_query($query): // 执 行 查询 操作 
} 
| 
<div align="right"> 共 <?php echo Smessage count;?> 条 记录 共 <?php echo Spage_ 


当前 第 <?php echo Spage;?> 页 
<2php 
if($page!=1){ // 判 断 ， 如 果 分 页 变量 值 不 为 1, 输出 下 面 的 超 链接 
echo "<a href=update.php?page=1> 首 页 </a>"; 
echo "<a href=update.php?page=".($page-1)."> 上 一 页 </a>"; 
。21 。 
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| 27 3 
| 28 if($page<$page_count){ 1/ 判断 ， 如 果 分 页 变量 小 于 总 的 记录 数 ， 
| 则 输出 下 面 的 超 链 接 
29 echo " <a href=update.php?page=".($page+1)."> 下 一 页 </a>"; 
30 echo " <a href=update.php?page=$page_count> 尾 页 </a>"; 
31 } 
E04 > 
上 面 代码 中 使 用 mysql_num rowsO 函 数 获取 select 查询 语句 查询 到 的 总 记录 数 ， 并 以 
ceil0 函 数 获取 总 页 数 。 


1.7.3 ”图 书信 息 管理 模块 实现 过 程 


图 书信 息 管理 模块 的 设计 效果 如 图 1.17 所 示 。 


1.17 ”图书 信息 管理 模块 设计 效果 


| 图 书信 息 管理 模块 实现 图 书信 息 的 分 页 浏览 、 修 改 、 删 除 和 查看 图 书 详细 信息 操作 ， 
下 面 分 别 对 各 项 功能 的 实现 方法 进行 介绍 。 


1.， 图 书信 息 分 页 浏览 
有 关 图 书信 息 分 页 浏览 的 内 容 请 参考 1.7.2 节 ， 这 里 不 再 獒 述 。 
2. 查看 图 书 详细 信息 


在 图 书 分 页 浏览 页 面 中 ， 当 用 户 单 击 图 书 名 称 超 链接 时 ， 将 进入 图 书 详细 信息 页 ， 根 
| 据 超 链接 传递 的 ID 值 ， 在 define.php 文件 中 输出 指定 图 书 的 所 有 信息 ，define.php 文件 的 
| 关键 代码 如 下 : 

代码 位 置 ， 配套 资源 \mr\01\define.php 


01 <?php 

02 include("conn/conn.php"): // 包 含 数 据 库 连接 文件 

03 iflisset($_GET[id])){ // 判 断 i 信息 是 否 存 在 

04 S$id=$_GET['id']: /获取 指定 图 书 的 ID 值 

05 $selectl=mysql_query("select * from tb_book where id='$id".$conn):// 执 行 查询 语句 
06 Sarrayl=mysql fetch array($select]): // 获 取 查 询 结 果 
07 } 

08 $select=mysql_query("select * from tb_book",$conn): ”// 查 询 所 有 图 书信 息 ， 供 搜索 使 用 
09 $array=mysql fetch array($select): 1/ 获取 所 有 图 书信 息 

10 > 

a <tr> 


| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
J 
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12 <td height="19" align="right"><div align="right"> 书 名 : </div></td> 

13 <tdalign="left">&nbsp:<?php echo $arrayl[books']:?></td> 

14 </tr> 

15 /省 略 部 分 代码 

16 <t> 

17 <td height="19" align="right"><div align="right"> 文 稿 存储 位 置 : </div></td> 

18 <td align="left">é&nbsp:<a target="_blank" href="<?php echo $array1 [bookpath] 
ea 

19 <?php echo $arrayl[bookpath]:?></a></td> 

20 </t> 

21 /省 略 部 分 代码 

22 <t> 

23 <td height="51" align="right"><div align="right"> 简 介 : </div></td> 

24 <td align="center" valign="middle">&nbsp: 

25 <textarea name="textarea2" cols="65" rows="3"><?php echo $arrayl ['synopsis]:?> 
</textarea></td> 

26 </tr> 

2 <t> 

28 <td height="100" align="right"><div align="right"> 目 录 : </div></td> 

29 <td align="center" valign="middle">&nbsp: 

30 <textarea name="textarea" cols="65" rows="6"><?php echo $arayl 【catalog]:?> 
</textarea></td> 

3 </tr> 


3. 修改 图 书信 息 


在 图 书 分 页 浏览 页 面 中 ， 当 用 户 单 击 “ 修 改 ” 超 链接 时 ， 将 进入 图 书信 息 修改 页 面 ， 
运行 效果 如 图 1.18 所 示 。 


5: DIE 

wal: EE 

二 可: Few 本 

Bi ES ET LE 
日 好: 

5 N21 呈 -1.169PHP 工 作 PHP 了 吉利 党 手 册 


CE SEEEREIIAUZTEETETEEEED 
NE: [NSZIESTISSWNRETPHPRE 拓 下 日 字 拉 有 
2 


1.18 图 书信 息 修改 页 面 
有 具体 实现 过 程 如 下 : 
(1) 在 图 书信 息 修改 页 面 创建 form 表单 ， 将 根据 超 链 接 传递 的 ID 值 ， 查 询 出 指定 
图 书 的 信息 ， 并 且 将 查询 结果 作为 表单 中 各 个 元 素 的 初始 值 进行 输出 ， 最 后 创建 “提交 ” 按 
钮 ， 将 数据 提交 到 update_ ok _ okphp 文件 中 ， 完 成 对 图 书信 息 的 修改 操作 ， 关 键 代码 如 下 : 


。23 。 


Size="50" 亡 
12 
13 
14 
15 
16 
19 
18 
19 
20 
2Y 

</option> 
22 
23 
24 
25: 
26 
27 
28 
29 
30 
Sl 
32 
33 
34 
35 


</option> 


iflisset($_GET["id']) and$_GET[id]'=nulD{ // 判 断 了 D 值 是 否 存在 
S$select3=mysql query("select * from tb_ book where id=".$ GET[id]."".$conn): 


// 查 询 指 定 的 图 书信 息 


$array3=mysql fetch array($select3):; // 获 取 查 询 结果 


<table width="527" height="321" border="0" cel ing="0" cellspacing="0"> 


<tr> 
<td width="112"><div align="left"> 书 名 : </div></td> 
<td width="415"><div align="left"> 
<input name="books" type="text"” value="<?php echo $array3['books]:?>" 


</div></td> 
</tr> 
<tr> 
<td><div align="left"> 类 别 : </div></td> 
<td><div align="left"> 
<select name="sort" id="sort"> 
<?php 
while($arrayl=mysql_fetch_array($select1)){ 1/ 循环 输出 类 别 
?> 
<option value="<?php echo $arrayl['sort]:?>"><?php echo $arrayl['sort]:?> 


<?php 


<t> 
<td><div align="left"> 语 言 : </div></td> 
<td><div align="left"> 
<select name="talk" id="talk"> 
<?php 
while($array2=mysql_fetch_array($select2)){ // 循 环 输出 语言 
?> 
<option value="<?php echo $array2['talk]:?>"><?php echo $array2['alk]:?> 
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41 </tr> 
42 <tr> 
43 <td><div align="left"> 简 介 : </div></td> 
44 <td><div align="left"> 
45 <input name="synopsis" type="text" value="<?php echo $array3['synopsis']:?>" 
size="50" /> | 
46 </div></td> 
47 </t> 
48 <t> 
49 <td><div align="left"> 目 录 : </div></td> 
50 <td><div align="left"> 
51 <textarea name="catalog” cols="40" id="catalog"><?php echo S$array3 | 
['catalog']:?></textarea> ! 
52 </div></td> | 
53 </tr> | 
54 <t> | 
55 <td><div align="left"> 文 稿 路 径 : </div></td> | 
56 <td><div align="left"> | 
3 <input name="bookpath" type="text" value="<?php echo $array3 [bookpath] | 
;2>" size="50" /> | 
58 </div></td> | 
59 </tr> | 
60 <tr> | 
61 <td><div align="left"> 程 序 路 径 : </div></td> | 
62 <td><div align="left"> | 
63 <input name="programpath" type="text" value="<?php echo $array3 [programpath']:?> | 
" size="50" /> | 
64 </div></td> | 
65 </t> | 
66 <t> | 
67 <td><div align="left"> 录 像 路 径 : </div></td> | 
68 <td><div align="left"> | 
69 <input name="videopath" type="text" value="<?php echo $array3 [videopath]:?> " | 
size="50" /> | 
70 </div></td> | 
71 </tr> | 
72 <t> | 
73 <td colspan="2"><div align="center"> | 
74 <input type="submit" name="Submit" value=" 提 交 " /> | 
75 <input type="submit' name="Submit2" value=" 取 消 " /> | 
76 <input type="hidden" name="id" value="<?php echo $array3 [id"]:?>"/><!-- 隐 | 
藏 域 -> | 
万 cdiv><htd> | 
78 </t> | 
79 </table> | 
| 
! 
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(2) 当 用 户 修改 完 信息 后 ， 单 击 “ 提 交 ” 按 钮 ， 在 数据 处 理 页 中 将 对 数据 库 中 的 数 
| 据 进行 修改 ， 其 关键 代码 如 下 : 
| 代码 位 置 ， 配套 资源 \mr\01\npdate_ok_ok.php 


[talk].", 


<?php 
header("Content-type:text/html:charset=utf-8"): /设置 文件 编码 
include("conn/conn php ): /包含 数据 库 连 接 文件 


ifisset($_ POST[Submit]) and $ POST[Submit] 一 "提交 "){ / 浏 断 “提交 ”按钮 是 否 存在 
$update=mysql query("update tb book set sort=".$ POST['sort].” ‘talk=".$ POST 


books=".$ POST['books'].",synopsis=".$_ POST['synopsis'].".catalog=".$ POST['catalog]."、 
bookpath=".$_POST['bookpath'].".programpath=".$_POST['programpath'].",videopath= 


"S_POST[videopath]m 


08 
09 
10 
也 
也 
13 
14 
3 


Where id=".$ POST[Tid]."".$conn): /执行 修改 语句 
if($update){ 
echo "<script>alert(' 修 改 成 功 ! "):window.location.href="update.php'</script>"; 
jelse{ 
echo "<script>alert( 修 改 失 败 ! ):windowlocation href-update_okphp'</script>": 
} 
} 


Ve 


4. 市 除 图 书信 息 


在 图 书 分 页 浏览 页 面 中 ， 单 击 “ 删 除 ” 超 链接 后 ， 将 跳 转 到 delete php 文件 中 ， 根 据 
超 链接 传递 的 ID 值 ， 应 用 delete 语句 完成 指定 图 书信 息 的 删除 操作 。Delete -php 文件 的 关 


代码 位 置 : 配套 资源 \mr\01\delete.php 


01 
02 
03 


<?php 
header("content-type:text/html:charset=utf-8"); /设置 文件 编码 
include("conn/conn.php"); // 包 含 数据 库 连 接 文 件 
这 isset($_GET['id])){ 1/ 判断 i 是 否 存 在 
Sdelete=mysql_query("delete from tb book where id="".$ GET['id'].""",$conn); 
// 执 行 删除 语句 
if($delete){ 


echo "<script>alert(' 删 除 成 功 ! "):window.location.href='"update.php'</script>"; 
}else{ 

echo "<script>alert( 删 除 失败 ! "):window.location.href='"update.php'</script>"; 
} 


— 
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1.8 图 书 搜索 模块 设计 


1.8.1 图 书 搜索 模块 概述 锚 


在 图 书 搜索 条 件 下 拉 列 表 中 选择 查询 条 件 ， 单 击 “搜索 ”按钮 ， 即 可 显示 搜索 结果 。 
图 书 搜索 模块 的 运行 效果 如 图 1.19 所 示 。 


图 1.19 图 书 搜索 模块 运行 效果 | 
1.8.2 通过 JavaScript 脚本 创建 级 联 下 拉 列 表 杠 


本 模块 通过 JavaScript 技术 判断 搜索 条 件 是 否 为 空 及 根据 用 户 选择 的 数据 更 改 相应 列 | 
表 中 的 数据 。 当 用 户 在 第 一 个 列表 中 选择 搜索 条 件 后, 第 二 个 列表 中 的 数据 也 将 随 之 改变 ， | 
并 与 第 一 个 列表 中 的 数据 相对 应 ， 关 键 代 码 如 下 : | 
代码 位 置 ， 配套 资源 \mr\01\select.php | 


01 <script> | 
02 function fetchO{ // 判 断 搜索 关键 字 是 否 为 空 | 
03 if(form1.key.value=—=""){ | 
04 alert(" 请 输入 搜索 关键 字 ! "); | 
05 forml.value selectO: | 
06 return false; | 
07 } | 
08 Tetum true; | 
09 )} | 
10 </script> | 
11 ‘<script language="javascript"> | 
12 function press(opt){ // 定 义 press0 方 法 ， 控 制 下 拉 列 表 框 select2 显示 的 值 | 
13 /opt 表示 现 有 可 选项 的 数目 | 
14 forml.select2.options[optj=new Option(ok=(forml.select2.options[opt)? | 
15 form! .select2.options[opt].innerText+String.fromCharCode(event.keyCode): | 
16 String.fromCharCode(event keyCode).ok) | 
i form!l.select2.selectedIndex=opt: | 
Ee | 
19 </script> | 
20 <script language="javascript"> | 
21 function up(op){ // 定 义 吧 0 方 法 控制 select2 的 值 | 
22 。 /opt 表示 现 有 可 选项 的 数目 | 
23 这 forml.select2.options[opt){ | 
24 if(event. keyCode—8){ | 
25 Var str=form!1 .select2.options[opt].inner Text: | 
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26 Var len=strlength: 
27 form! .select2.0options[opt].innerText=str.substring(0.len-1): 
28 if(form!l.select2.0ptions[opt].innerText—" ")select2.remove(2): 
29 } 
30 iflevent.keyCode=—=32){ 
31 forml.select?2.options[opt].innerText+=" "; 
2 } 
| 33 } 
34 = 
35 </script> 


1.8.3 ”图 书 搜索 模块 实现 过 程 
图 书 搜索 模块 的 页 面 设计 效果 如 图 1.20 所 示 。 


图 1.20 图 书 搜索 模块 设计 效果 


| 具体 实现 过 程 如 下 : 
| (GD 创建 omm 表单 ， 添 加 下 拉 列表 框 “ 搜 索 ”按钮 ， 将 查询 的 关键 字 提 交 到 本 页 ， 
其 关键 代码 如 下 : 


| 代码 位 置 ， 配套 资源 \mr\01\select.php 


| 01 <table width="758" height="23" border="0" cellpadding="0" cellspacing="0"> 


| 02 <tr> 

| 03 <td width="206"><div align="right" class="STYLE2"> 图 书 搜索 ;</div></td> 

| 04 <td width="159"><table> 

| 05 <form id="list" name="list" method="post"> 

| 06 <tr> 

| 07 <td width="125" align="left" valign="middle"> 

| 08 <select name="select" onchange="javascTipt:listsubmitO"> 

| 09 <option value="" selected="selected"> 请 选择 </option> 

| 10 <option value="Famous_Id"> 类 别 </option> 

| 11 <option value="Famous_Ids"> 语 言 </option> 

| 这 <option value="boo_name"> 书 名 </option> 

| 13 <option value="jianjie"> 简 介 </option> 

| 14 <option value="mulu"> 目 录 </option> 

| 15 </select></td> 

| 16 </tr> 

| 17 </form> 

| 18 </table></td> 

| 19 <td width="295"><table width="254" height="29" border="0" cellspacing="0" 
| cellpadding="0"> 

| 20 <form id="forml" name="forml" method="post” action="select.php" onkeypress= 


"pressG)" onkeyup="up(3)"> 
> | 。28 。 
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2 <tr> | 
2 <td width="110"><select name="select2"> | 
23 <option selected="selected"> 请 选择 </option> | 
24 <?php | 
25 ifisset($_POST[select]){ | 
26 Sselect=$_ POST['select]: | 
27 这 $select 一 "Famous Id"){ Note 
28 $sel=mysql_query("select * from tb_sort".$conn); // 查 询 图 书 类 别 | 
29 while($arr=mysql. fetch array($sel){ | 
30 ?> | 
31 <option value="<?php echo Sanfsort]?>"><?php echo Sanfsort]?> </option> | 
32 <?php | 
33 } | 
34 jelse ifSselect 一 "Famous Ids"){ | 
35 $sell=mysql_query("select * from tb_program",$conn); // 查 询 图 书 语言 | 
36 while($arrl=mysql fetch array($sell)){ | 
37 ?> | 
38 <option value="<?php echo $arr1['talk'"]:?>" selected="selected"> | 
39 <?php echo $arrl['alk]:?></option> | 
40 <?php | 
41 } | 
42 }else{ | 
43 > | 
44 <option value="<?php echo $arrl['alk]:?>" selected="selected"> | 
45 <?php echo $arr1['talk']:?></option> | 
46 <2php | 
47 } | 
48 } | 
49 ?> | 
50 </select> | 
51 <htd> | 
52 <td width="144"> | 
53 <input type="image" name="imageField" src="images/book 05 02.gif' onclick= | 
"retum fetchO:" /></td> | 
54 <> | 
55 </form> 
56 </table></td> 
57 </t> 
58 </table> 


页 面 设计 完成 后 ， 开 始 编写 JavaScript 脚本 ， 判 断 搜索 条 件 下 拉 列 表 的 相关 代码 〈 在 
1.8.2 节 中 有 详细 介绍 ， 此 处 不 再 装 述 )。 

(2) 在 本 页 中 , 根据 form 表单 提交 的 关键 字 执 行 查询 操作 ， 分 页 循环 输出 查询 结果 ， 
关键 代码 如 下 : 

代码 位 置 : 配套 资源 \mr\01\select.php 


01 <<table width="606" height="90" border="0" cellpadding="0" cellspacing="0"> 
。29 。 
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<tr> 
<td width="305" height="33"><div align="center"> 书 名 </div></td> 
<td width="301"><div align="center"> 发 布 日 期 </div></td> 
</tr> 
<2php 
iflisset($_POSTT['select2"])){ 
$key=$ POSTT['select2"]: 
S$sell=mysql_query("select * 位 om tb_book where sort=".$_POST['select2"]." 
or talk=".$ POST['select2']." or catalog like '%$key%' 
or synopsis like '%$key%%' or books like %$key%".$conn): // 执 行 模糊 查询 语句 


S$count=mysql_ num rows($sell); /获取 查询 结果 
if($count>0){ 
while($arr=mysql fetch array($sel1)){ // 循 环 输出 查询 结果 
?> <tr> 


<td height="27"> 
<a href="define php?id=<?php echo $arfid]:?>"><?php echo $arrf'books']:?> 


<td><?php echo Sarfdate].?></td> 
</tr> 
<2php 
号 
jelse{ 
echo "<script>alert( 对 不 起 ， 没 有 您 要 查找 的 内 容 ! '):window.location hre 合 


} 
! 
> 
<?php 
让 (isset($_GET[page]){ // 淹 断 分 页 变量 是 否 为 空 
Spage=$_GET['page']: /定义 分 页 变量 ， 并 且 赋 值 
jelse{ 
3 Spage=1; // 如 果 分 页 变量 不 存在 ， 则 为 其 赋 空 值 
} 
if($page){ 
Spage_size=12:; // 每 页 显示 记录 数 
S$page_count=ceil($count/$page_size): // 总 页 数 
S$offset=($page-1)*$page_size: /计算 每 页 的 起 始 行 数 


/定义 SQL 语句 ， 查 询 当 前 页 显示 的 记录 
$query="select * fiom tb books where id order by id desc limit $offset, Spage size": 
Sresult=mysql_query($query): // 执 行 查询 操作 
} 
?> 
<tr> 
<td height="30" colspan="2"><div align="right"> 
<div align="right> 共 <?php echo $count?> 条 记录 共 <?php echo $page_count:?> 页 
当前 第 <?php echo $page:?> 页 
<?php 
if($page!=1){ 


。30 。 
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48 echo "<a href=update.php?page=1> 首 页 </a>"; | 
49 echo "<a href-update php?page="(Spage-1). "> 上 一 页 </a>": | 
50 } | 
53Y if($page<$page count){ | 
52 echo " <a href-update. php?page=".($page+1)."> 下 一 页 </a>"; | 会 A 
53 echo " <a href=update.php?page=$page_count> 尾 页 </a>"; | 一 一 
54 } | 
55 > Note 
56 </div></td> | 
ST </t> | 
58 </table> | 
| 
1.9 项 目 发 布 


1. 搭建 PHP 运行 环境 


由 于 笔者 在 开发 项 目 时 应 用 AppServ 集成 化 安装 包 搭建 的 PHP 运行 环境 ， 所 以 建议 | 
读者 也 应 用 AppServ 来 搭建 PHP 运行 环境 ， 这 样 可 以 确保 项 目 正常 运行 。 | 
如 果 选 择 手动 配置 PHP 运行 环境 ,或 者 通过 WAMP、XAMPP 等 其 他 集成 化 安装 包 来 搭 | 
建 PHP 运行 环境 ， 那 么 在 运行 本 书 中 的 项 目 时， 可 能 会 出 现 一 些 不 必要 的 错误 。 因 为 不 同 的 


集成 化 安装 包 在 配置 上 会 存在 一 些 差别 ， 所 以 强烈 建议 使 用 AppServ 来 措 建 PHP 运行 环境 。 | 
2， 具 体 项 目 发 布 方法 | 
发 布 本 项 目的 具体 方法 如 下 : | 


| - - - 带 格 式 的 : 项 目 符号 和 


4 


(1) 将 程序 文件 夹 01 复 制 到 AppServ 安 装 后 的 www 文 件 夹 下 。 

(2) 在 01 文 件 夹 下 ， 查 看 是 否 存在 data 文 件 夹 ， 如 果 存 在 ， 则 说 明 此 程序 应 用 到 数据 库 。 
如 果 是 MySQL 数据 库 ， 那 么 将 data 文 件 夹 下 的 数据 库 文件 夹 复制 到 本 机 AppSerWMySQLdata 
文件 夹 下 ， 并 且 去 掉 数 据 库 文件 的 只 读 属性 。 

(3) 最 后 确定 本 机 设置 的 MySQL 数据库 密码 与 程序 中 设置 的 默认 密码 是 否 相 同 〈 程 
序 中 设置 的 数据 库 用 户 名 是 root， 密 码 是 111) 。 | 


本 章 小 结 


本 章 主 要 介绍 图 书信 息 管理 系统 的 基本 创建 流程 、 开 发 思路 以 及 主要 功能 模块 的 实现 
过 程 。 通 过 本 章 的 学 习 ， 读 者 可 以 掌握 以 下 几 点 内 容 。 

(1) 如 何 获取 超 链接 传递 的 数据 。 

(2) 如 何在 下 拉 菜 单 中 动态 输出 数据 。 

(3) 数据 的 分 页 输出 方法 。 

(4) 创建 级 联 菜 单 的 方法 。 


。31 。 a 
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会 议 管理 系统 


( PHP+ADODB+Access 实现 ) 
自学 视频 、 源 程序 : 配套 资源 MnmA2\ 


随 着 信息 技术 的 高 速 发 展 ， 各 大 企业 的 多 项 管理 模式 也 先后 进入 了 快速 、 
有 效 、 便 捷 的 信息 化 阶段 ， 并 已 成 功 取代 部 分 传统 的 管理 模式 。 信 息 化 管理 是 
一 种 在 各 大 企业 中 应 用 十 分 广泛 的 新 型 管理 模式 ， 其 稳定 、 高 效 的 将 点 ， 一 直 
受到 各 大 企业 的 青 上 时。 信息 化 管理 简单 地 说 就 是 一 种 以 信息 技术 为 基础 ， 利 用 
计算 机 硬件 、 软 件 进行 有 效 管理 的 方式 ， 俊 羽 会 议 管理 系统 就 是 其 中 一 个 典型 
应 用 。 

通过 阅读 本 章 ， 读 者 可 以 学 到 : 


如 何 进 行 系统 分 析 

数据 库 设 计 流 程 
搭建 系统 架构 的 方法 
ADODB 类 库 技 术 的 应 用 

ADODB 类 库 操 作 Access 的 使 用 方法 
WebBrowser 预览 与 打印 的 实现 方法 
生成 Excel 报表 的 实现 方法 

分 类 查询 应 用 

文件 上 传 的 实现 方法 


于 于 于 瑟瑟 于 于 于 至 
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2.1 项 目 设 计 思 路 


2.1.1 功能 阐述 


俊 羽 会 议 管理 系统 的 结构 特点 是 对 不 同 权限 的 用 户 显示 不 同 的 操作 界面 ， 即 普通 用 户 
可 以 执行 添加 、 浏 览 、 查 找 会 议 记 录 等 操作 ; 管理 员 用 户 可 以 执行 普通 用 户 的 全 部 操作 ， 
并 且 可 以 对 用 户 账户 、 会 议 信 息 以 及 部 门 进行 管理 操作 。 


2.1.2 系统 预览 


俊 羽 会 议 管理 系统 由 多 个 功能 模块 组 成 ， 为 了 让 读者 对 本 系统 有 初步 的 了 解 和 认识 ， 
下 面 列 出 儿 个 具有 典型 功能 的 页 面 ， 其 他 页 面 请 参见 配套 资源 中 的 源 程序 。 

俊 羽 会 议 管理 系统 的 登录 页 面 如 图 2.1 所 示 ， 要 想 正常 使 用 俊 羽 会 议 管理 系统 ， 用 户 
必须 执行 登录 操作 ， 登 录 成 功 后 才 可 以 正常 使 用 该 系统 。 

系统 的 主页 如 图 2.2 所 示 。 正 常 登录 后 ， 普 通用 户 可 以 执行 添加 、 浏 览 、 查 找 会议 记 
录 以 及 更 改 用 户 个 人 密码 的 操作 ; 管理 员 用 户 还 可 以 执行 如 用 户 管理 、 会 议 记 录 管 理 等 管 
理 操作 。 


把 个 曙 全 放 fm 有 5 


JUNYU HUIYI GUANLI XITONG 


用 户 登 录 
[= | po . 
密码 00000 | 
Ea | 
| 
图 2.1 用 户 登录 界面 图 2.2 俊 羽 会 议 管理 系统 主页 


会 议 信 息 浏 览 页 面 如 图 2.3 所 示 ， 该 页 面 主要 向 用 户 展示 会 议 的 编号 、 名 称 、 地 点 等 | 
信息 ， 并 可 执行 报表 导出 、 查 看 会 议 详情 等 操作 。 


会 议 信 息 训 览 
部 门 名 称 会 议 地 点 。。 会 议 日 期 ”主持 人 出 库 人 员 记录 人 会 议 摘要 查看 详情 
ne 大 会 议 室 2010-4-2 。 Tommy Leons Rose Leon 分 配 工作 任务 EE 


2010-1-1 。 Jeff Leon Mlike Leon 系统 二 次 开发 EE 
| 


图 2.3 会 议 信息 浏览 页 面 


在 会 议 信息 浏览 页 面 单 击 吉 看 详情 图 标 ， 可 进入 打印 详情 页 面 ， 该 页 显示 如 图 24 所 | 
示 ， 用 于 执行 打印 预览 和 打印 操作 ， 单 击 “ 打 印 预览 ”按钮 可 以 查看 打印 效果 ; 单 击 “ 打 


3 L_ 


内 


(Eap 项 目 业 全 分 析 


| 印 ” 按 负 可 对 该 会 议 内 容 执行 打印 操作 。 


明日 科技 有 限 公 司 会 议 记录 详情 
| 人 ET Pp= 玫 
久 | 部 18: mw 人 si 宇 
食 放 | | sa ae aasA: mre 
a | 出 席 人 页 : Leon Nike 会 议 记录 人 : en 


| 
会 汉 捕 要 : 系统 二 次 开发 
Mote 总 中 


会 汉 忆 录 管 理 系 时 的 开发 。 开 必要 求 : 支 的 W012 打印 、 支 持 TEL 导出 ,nethecess。 开发 内 容 : 全 
议 信息 包括 会议 畏 号 、 研 这 名 称 ， 部 门 名 称 、 会 识 地 点 等 项 息 ， 功 能 要 求 ; 震 加 会 议 记录 ; 出 物 所 有 
会 议 记录 ; 会 议 编号 和 会 这 名 称 查 洒 会 议 记录 ; 修改 会 议 记录 , 


打印 预览 打印 


图 2.4 打印 详情 页 面 


2.1.3 功能 结构 
俊 羽 会 议 管理 系统 的 功能 结构 如 图 2.5 所 示 。 


俊 羽 会 议 管理 系统 结构 图 


| 普通 用 户 模 式 管 理 员 模式 


| 会 | |[ 浏 | | 查 | |[ 答 会 
| 议 览 | | 找 | | 理 2 
| 记 | | 会 | | 会 | | 用 上 
| 录 | | 议 | | 议 | | 户 全 
添 | | 信 | | 记 | | 信 | 
加 | | 息 | | 录 | | 号 
I I [ 1 
会 | | 会 设 || 六 || 四 | | 六 || 必 | | 硬 | | 本 | | 本 
! Fe kee i 1 裤 了 
二 | | 这 下 置 || 结 || 除 || 加 || 会 | | 会 | | 加 | | 除 
示 表 密 权 || 账 || 账 || 用 || 议 议 部 部 
| 加 | | 翅 | 限 || 记 ||| 户 || 记 | |] 记 | | 
| | 和 录 | | 录 


| 图 2.5 俊 羽 会 议 管理 系统 功能 结构 图 
”2.1.4 文件 组 织 结构 


| 编写 代码 之 前 ， 可 以 把 系统 中 可 能 用 到 的 文件 夹 先 创 建 出 来 例如， 创建 一 个 名 为 
| images 的 文件 夹 ， 用 于 保存 程序 中 所 使 用 的 图 片 )， 这 样 不 但 可 以 方便 以 后 的 开发 工作 ， 
| 也 可 以 规范 系统 的 整体 架构 。 本 项 目 应 用 的 是 ADODB 操作 Access 数据 库 ， 项 目的 文件 
| 目录 结构 如 图 2.6 所 示 。 


区 。34 。 
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Bn 会 议 管理 系统 目录 
BB adodb adodb 类 库 目 录 

自 -oa 连接 数据 库 配置 目录 
BB -ss css 样 式 目录 
Er 数据 库 目录 
回 insges 页 面 背景 图 片 目录 
Bi JavaScript 脚 本 目录 
wfile 会 议 文本 文档 上 传 目 录 


图 2.6 俊 羽 会 议 管理 系统 组 织 结构 图 
2.2 数据 库 设计 


2.2.1 数据库 设计 结 


无 论 是 什么 系统 软件 ， 其 最 根本 的 功能 就 是 对 数据 的 操作 与 使 用 ， 所 以 一 证 要 和 做 好 
数据 的 分 析 、 设 计 与 实现 ， 然 后 再 实现 对 应 的 功能 模块 。 

俊 羽 会 议 管理 系统 中 , 采用 的 是 Access 数据 库 ， 主 要 用 来 存储 会 议 信息 等 。 这 里 将 数 | | 
据 库 命名 为 db_meeting， 其 中 包含 的 数据 表 如 图 2.7 所 示 。 | 


会 议 记录 信息 表 | 
用 户 信息 表 


部 门 信息 表 | 一 一 一 一 一 一 一 一 


图 2.7 俊 羽 会 议 管理 系统 数据 表 
2.2.2 ”数据 表 设 计 结 构 
下 面 来 看 各 个 数据 表 的 结构 和 字段 说 明 。 
1. tb_meeting_user (用 户 信 息 表 ) 
用 户 信息 表 主 要 用 于 存储 用 户 的 信息 ， 其 结构 如 图 2.8 所 示 。 


[mv -ic -= 去 

| Bsa | 说 明 已 
下 Ea 用 户 10 

本 用 户 名 称 

文本 用 户 客 码 

ate ER 时 间 用 户 最 后 车 陆 时 间 

状 字 用 户 导 陆 次 狂 

因 字 用 户 可 限 

Ea 用 户 是 去 祛 泛 结 

文 机 用 户 所 展 部 门 

I 
于 和 


图 2.8 用 户 信息 表 结构 
0 L_ 


人 Pp 项 目 革 说 分析 


Ex % 
2. tb_meeting info (会 议 记录 信息 表 ) 


| 会 议 记录 信息 表 主 要 用 于 添加 会 议 的 相关 信息 ， 如 会 议 编号 、 名 称 、 部 门 、 日 期 、 出 
Ap | 席 人 员 等 多 种 信息 ， 其 结构 如 图 2.9 所 示 。 
会” | 


图 2.9 会 议 记 录 信 息 表 结构 


3. tb_meeting depart ( 部 门 信息 表 ) 
部 门 信息 表 主 要 用 于 存储 应 用 该 系统 的 企 事业 单位 的 相关 部 门 ， 其 结构 如 图 2.10 所 示 。 


图 2.10 部门 信 息 表 结构 


2.2.3 连接 数据 库 


| 由 于 系统 大 部 分 页 面 都 需要 使 用 数据 库 ， 如 果 每 页 都 编写 相同 的 数据 库 连接 代码 ， 会 显 
| 得 十 分 烦琐 ， 所 以 本 系统 将 数据 库 连接 代码 单独 存 入 一 个 PHP 文件 conn php 中， 在 需要 与 
| 数据 库 连 接 的 页 面 中 , 使 用 包含 函数 包含 该 文件 即 可 , 该 系统 实现 与 数据 库 连 接 的 代码 如 下 : 


01 <2php 

02 S$root=$_SERVER['DOCUMENT _ ROOT]; // 服 务 器 目录 

03 S$len=strripos($ SERVER[REQUEST URI"],"/"); // 获 取 文 件 执行 的 根 目录 
04 S$tmp=substr($_SERVER['PHP SELF'],0.,$len); 1/ 获取 文件 的 根 目 录 

05 Snewpath=$root.$tmp."/db/db_meeting.mdb":; 

06 include "adodb/adodb.inc php": // 载 入 adodb 

07 $conn=ADONewConnection('access’); // 建 立 access 连接 

08 $conn->Pconnect("Driver={Microsoft Access Driver (*.mdb)}:Dbq=$newpath"); 

09 $conn->execute("set names gb2312"): /设置 编码 格式 

10 > 


2.3 ”登录 模块 设计 


| 2.3.1 登录 模块 概述 


| 出 于 对 会 议 内 容 保密 性 的 考虑 ， 俊 羽 会 议 管理 系统 不 支持 匿名 用 户 访问 ， 所 以 用 户 如 
| 果 想 要 正常 使 用 该 系统 ， 首 先 必须 执行 用 户 登录 操作 ， 在 登录 成 功 后 ， 才 可 以 进行 会 议 记 


忆 。36 。 
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录 的 添加 、 查 看 和 查找 等 操作 。 登 录 模 块 的 运行 结果 如 图 2.11 所 示 。 


(0D 化 约会 六 a 


JUNYU HUIYI GUANLI XITONG 


用 户 登录 
(2 用 户 名 wr 
密 至， | eeee 
3 EE 


图 2.11 登录 模块 运行 效果 
2.3.2 ”用 户 权限 判断 技术 


在 index.php 文件 中 通过 SESSION 变量 自动 判断 登录 状态 。 如 果 用 户 登 录 状 态 被 激活 ， 
则 自动 跳 转 到 会 议 管理 首页 ， 否 则 ， 跳 转 到 用 户 登录 界面 ， 其 代码 如 下 : 
代码 位 置 ， 配套 资 源 \mr\02\index.php 


01 <?php 

02 session_ start(); 

03 /判断 当前 登录 状态 

04 iflisset($_SESSION["name'"]) and isset(S_SESSION["id"]) and isset($_SESSION ["rights"])){ 
05 echo "<meta http-equiv=\"refresh\" content=\"0;url=manager.php\" />"; 


06 }else{ 

07 echo "<meta http-equiv=\"refresh\" content=\"0;url=login.php\" />"; 
08 } 

I> 


2.3.3 ”用 户 登 录 模块 实现 过 程 


创建 前 台 登 录 页 面 〈login.php) 完成 用 户 登 录 表 单 的 设计 ， 当 单 击 “ 登 录 ” 按 钮 时 ， 
将 用 户 名 和 密码 提交 到 处 理 页 (login_chk.php)， 完 成 登录 用 户 的 验证 操作 。 
login.php 文件 的 关键 代码 如 下 : 


代码 位 置 ， 配套 资源 \mr\02\login.php 


01 <table cellpadding="0" cellspacing="0"> 


02 <form method="post" action="login_chk.php"> 
03 <tr> 
04 <td width="58" height="42"><div align="right"> 用 户 名 :</div></td> 


05 <td width="163"><input class="inputl" id="usermame" type="text" name="username" 

06 onmouseover="this.style.backgroundColor="#deebef'" onmouseout="this.style. 
back groundColor=""/></td> 

07 </t> 


。37 。 


人 Bo 项 目 业 例 分 析 


CS 
08 <tr> 
09 <td width=-"58" height="42"><div align="right"> 密 &nbsp;&nbsp; 码 :</div></td> 
10 <td width="163"><input class="input2" 1d="pass" type="password" name="pass" 


bs onmouseover="this.style.backgroundColor='#deebef'" onmouseout="this.style. 
backgroundColor=""/></td> 
12 </tr> 


| <tr> 
<td colspan="2" height="22"><center> 
15 <input name="submit" type="submit" class="btnlogin" value=""/> 
16 &nbsp: 
17 <input name="reset" type="reset" class="btnreset" value="" /></center> 
18 </td> 
19 </tr> 
20 </form> 


21 </table> 


登录 处 理 文件 login_chk.php 完成 对 系统 提交 数据 的 判断 , 并 且 更 新 用 户 登录 的 次 数 和 
时 间 。 其 关键 代码 如 下 : 
代码 位 置 ， 配套 资源 \mr\02\login_chk.php 


。38 。 


1 
| 01 <2php 
| 02 session start(); 
| 03 include once("conn/conn.php"): // 加 载 数据 库 连接 文件 
| 04 if(empty($_POST["usermmame"]) or empty($_ POST["pass"])){ 
| 05 echo "<script>alert( 用 户 名 和 密码 不 能 为 空 ! ");history.go(-1);</script>"; 
| 06 }else{ 
| 07 $username=$ POST["username"]; 
| 08 $pass=$_POST["pass"]; 
| 09 Ssqltest="'select * from tb_meeting_user Where userName='$username'"; 
| 1/ 判断 登录 用 户 名 是 否 存 在 
| 10 Stestrst=$conn->Execute($sqltest); // 执 行 查询 操作 
| 11 if(!$testrst->EOF){ 
| 12 Ssqlstr="'select * from tb_meeting_user where userName='$username' and userPassword 
| ='$pass'"; 
| 13 S$rst=$conn->Execute($sqlstr); 
| 14 if(!S$rst->EOF){ 1/ 判断 登录 用 户 名 和 密码 是 否 正 确 
| 15 if($rst->fields[6]—0){ // 判 断 登 录用 户 是 否 被 冻结 
| 16 $_SESSION["id"]=Srst->fields[0]: /赋值 给 SESSION 变量 
| 17 $_SESSION["name"]=$rst->fields[1]: 
| 18 $_SESSION["rights"]=Srst->fields[5]: 
| 19 $_SESSION["lasttime"]=$rst->fields[3]: 
| 20 Slogindate=date("Y-m-d ").date("G:i:s"); // 当 前 登录 时 间 
| 2l Slogincount=$rst->fields[4]; // 当 前 登录 次 数 
| 22 S$logincount++; // 登 录 次 数 自 增 1 
| 23 Ssqlstrud="update tb_meeting_user set userLoginCount=Slogincount,userLast 
| LoginDate='$logindate' 
| 24 whereuserId=$ SESSION[id]"; // 更 新 登录 次 数 和 时 间 
| 25 $conn->Execute($sqlstrud); 
| 26 echo "<meta http-equiv=\"refresh\" content=\"2;url=manager.php\" />"; 
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2 echo "<img src='images/loginwait.jpg' width 一 1003' height="636' />"; 
28 Yelse if($rst->fields[6]—1){ 
29 echo "<script>alert(' 该 用 户 账号 已 被 冻结 请 联系 管理 员 ! ');history. 
go (-1);</script>"; | 
30 v | 了 
31 jelse{ | 食 -| 
32 echo "<script>alert( 密 码 错误 ， 请 重新 登录 。');history.go(-1);</script>"; | 
3 ) 
34 }else{ 
35 echo "<script>alert( 该 用 户 名 不 存在 !， 请 重新 登录 。');history.go(-1);</script>"; 


当 用 户 登录 成 功 后 ， 页 面 会 在 2 秒 后 自动 跳 转 到 俊 羽 会 议 管理 系统 的 主 界面 。 


24 首页 设计 


首页 一 般 没 有 多 少 实质 的 技术 ,主要 是 加 载 一 些 功能 模块 ,如 用 户 信息 、 导 航 栏 模块 ，| 
使 浏览 者 了 解 网 站 的 内 容 和 特点 。 首 页 的 重要 之 处 是 要 合理 地 对 页 面 进行 布局 ， 既 要 尽 可 | 
能 地 将 重点 模块 显示 出 来 ， 同 时 又 不 能 因为 页 面 凌乱 无 序 ， 而 让 浏览 者 无 所 适 从 、 产 生 反 
感 。 本 系统 首页 的 运行 结果 如 图 2.12 所 示 。 


从 条 抽 晶 角 :11 四 导 5E 上 兴 当 二 。 zll- 沾 -1 or 过 前 为 项 到 次 好 


当前 位 置 > 首页 


下 理 吉 入 用 三 二 议 记 亲 和 人 1 
eshte 
eA， 旧 间 史家 硬 内 上 市 全 引起 二 作 和 

Be A TL 


图 2.12 系统 首页 运行 结果 
2.4.2 首页 设计 技术 


在 系统 首页 中 应 用 switch 语句 , 实现 不 同 功能 模块 在 首页 中 的 展示 。switch 语句 在 PHP 
动态 文件 中 使 用 , 根据 超 链接 传递 的 值 ,包含 不 同 的 功能 模块 ， 从 而 达到 页 面 切换 的 效果 。 | 


2 30 Ee 
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| 首先 从 URL 地 址 栏 获取 GET 传递 参数 值 ， 然 后 通过 switch 语句 判断 变量 的 值 ， 来 加 
| 载 对 应 模块 。switch 语句 应 用 关键 代码 如 下 : 


| 01 $lmbs=$ GET["Imbs"]; // 从 URL 地 址 中 获取 GET 传递 参数 并 赋值 给 变量 
贪 站 | 02 switch($lmbs); // 判 断 变 量 是 否 符合 相应 条 件 
| 03 case "添加 会 议 记录 ": 
04 include("addmeeting.php"); 。 // 根 据 获取 的 变量 加 载 相 应 模块 程序 
| 05 break: 
06 EE 
07 Case "": 
08 include(“welcome.php"); 
09 break; 


| switch 语句 与 论语 句 相 似 。 很 多 场合 下 需要 把 同一 个 变量 (或 表达 式 ) 与 很 多 不 同 的 
| 值 比较 ， 并 根据 它 等 于 哪个 值 来 执行 不 同 的 代码 。 其 中 ，case 表达 式 可 以 是 任何 值 为 简单 
| 类 型 的 表达 式 ， 即 整 型 、 浮 点 数 以 及 字符 串 。 但 不 能 用 数组 或 对 象 ， 除 非 它们 被 解除 引用 
| 成 为 简单 类 型 。 


| 2.4.3 ”首页 实现 过 程 


俊 羽 会 议 管理 系统 首页 的 实现 过 程 如 下 。 
| (1) 创建 index.php 动态 页 。 在 index.php 动态 页 中 ， 应 用 include_once0) 语 句 包含 相 
， 应 的 文件 , 判断 用 户 是 否 正 常 登录 系统 ， 如 果 不 是 正常 登录 ， 则 跳 转 到 login.php 用 户 登 录 
| 页面， 如 果 正常 登录 ， 则 跳 转 到 managerphp 页 。 关 键 代码 如 下 : 
代码 位 置 ， 配 套 资源 \mr\02\index.php 
01 <?php 
02 session_ start(); 
03 /判断 当前 登录 状态 
04 ifisset($_SESSION["name'"]) and isset($_SESSION["id"]) and isset($_SESSION["rights"]){ 
05 echo "<meta http-equiv=\"refresh\" content=\"0;url=manager.php\" />"; 


06 }else{ 

07 echo "<meta http-equiv=\"refresh\" content=\"0;url=]login.php\" />"; 
08 } 

09 > 


| (2) 创建 managerphp 文件 ， 应 用 include_once0 语 句 包含 相应 的 文件 ， 判 断 用 户 是 
| 否 正常 登录 系统 ， 然 后 应 用 switch 语句 ， 以 超 链接 中 参数 Imbs 传递 的 值 为 条 件 进行 判断 ， 
| 实现 在 不 同 页 面 之 间 跳 转 。managerphp 的 关键 代码 如 下 : 

| 代码 位 置 ， 配 套 资源 \mr\02\manager.php 


01 <?php 

02 session start(); 

03 include_once("conn/conn.php"); 
04 > 


05 <- 省 略 部 分 HIML 代码 -> 


06 <?php 

07 if(empty($_SESSION["name"]) and empty($_SESSION["id"]){ // 判 断 当 前 用 户 是 
否 为 登录 状态 

08 ”echo "<scripf>alert(' 请 登录 后 再 进行 执行 操作 ! ):history.go(-D):</scripf>": 

09 jelse{ 

10 yw 

11 <!-- 省 略 部 分 HTML 代码 --> 

12 <table cellpadding="0" cellspacing="0" border="0"> 

13 <tr> 

14 <td width="180"> 

15 <div class="leftbox"> 

16 <center> 

17 <h4 class="h4"> 分 类 操作 </h4> 

18 <uUl> 

19 <li><ahre 人 "managerphp?lmbs= 添 加 会 议 记 录 ">&nbsp:&nbsp: 添 加 会 议 记录 <a><i> 

20 <Li><ahref- managerphp?imbs= 浏 览 会 议 记 录 ">&nbsp;&nbsp: 浏 览 会 议 信息 <a><li> 

21 <i><ahre 全 "managerphp?lmbs= 查 找 会 议 记 录 ">&nbsp:&nbsp: 查 找 会 议 记 录 </a><i> 

22 <1i><a href="managerphp?lmbs=- 管 理 用 户 信息 ">&nbsp;&nbsp; 管 理 用 户 信息 <Ja></li> 

23 </ul> 

24 <p>&nbsp;</p> 

25 <2php 

26 if($_SESSION["rights"]=——1){ 

2 > 

28 <h4 class="h4style"> 管 理 操作 </h4> 

29 <u> 

30 <li class="uli"><a hre 全 "managerphp?lmbs= 用 户 账户 管理 ">&nbsp:&nbsp: 用 户 
账户 管理 </a></li> 

31 <li class="uli"><a href="manager.php?lmbs= 会 议 信 息 管理 ">&nbsp;&nbsp: 会 议 
信息 管理 </a></li> 

32 <li class="uli"><a hre 全 "managerphp?lmbs= 部 门 管理 ">&nbsp:&nbsp: 部 门 管理 
</a></l> 

33 <u> 

34 <2php 

35 } 

36 ?> 

37 </center> 

38 <!-- 省 略 部 分 HTML 代码 --> 

39 </div> 

40 </td> 

41 <td width="784"> 

42 <div class="rightbox"> 

43 <div class="position"> 当 前 位 置 >> 

44 <?php 

45 这 empty($_GET["lmbs"])){ // 判 断 URL 传递 是 否 为 空 

46 echo "首页 ": 

47 yelse{ 

48 echo $_GET["Imbs"]: 

49 } 

50 ?></div> 
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51 <div class="include"> 
| 52 <?php 
| 53 $lmbs=$_GET["Imbs"]:; // 通 过 不 同 的 URL 参数 加 载 相应 的 页 面 
| 54 switch(Slmbs){ 
| 55 case "添加 会 议 记 录 ": 
| 56 include("addmeeting.php"); 
SH break; 
58 case "浏览 会 议 记录 ": 
| 59 include("viewmeeting .php"); 
| 60 break; 
| 61 case "查找 会 议 记 录 ": 
| 62 include("found php"); 
| 63 break: 
| 64 case "修改 密码 ": 
| 65 include("amendpwd.php"): 
| 66 break; 
| 67 case "查找 会 议 结果 ": 
| 68 include("show.php"): 
| 69 break: 
| 70 case "管理 用 户 信息 ": 
| 71 include("amendinfo. php: 
| 72 break: 
| 73 Case "". 
| 74 include("welcome.php"); 
| 7 break: 
| 76 // 管 理 员 模 式 选项 
| 77 case "用 户 账户 管理 ": 
| 78 include("acc_managerphp'"); 
| 79 break; 
| 80 case "会 议 信 息 管理 ": 
| 81 include("recordmanager.php"); 
| 82 break: 
| 83 case "部 门 管理 ": 
| 84 include("departmanager.php"); 
| 85 break; 
86 } 
| 87 ?> 


| 说明: 
本 系统 的 首页 代码 较 多 , 对 于 初学 者 来 说 在 代码 阅读 方面 可 能 会 存在 一 些 困 难 。 所 以 ， 
| 上述 代码 只 给 出 了 主要 部 分 ,部 分 HTML 代码 被 省 略 ,读者 可 参看 配套 资源 内 的 完整 内 容 。 


2.3 用 户 个 人 信息 模块 设计 


2.5.1 用 户 个 人 信息 模块 概述 
用 户 登 录 后 ， 即 可 看 到 个 人 的 相关 信息 。 在 这 里 ， 用 户 可 以 查看 个 人 用 户 名 称 、 权 限 


J . 42 . 


第 2 章 会 议 管理 系统 (PHPHADODB+qccess 实现 ) § 


等 级 、 当 前 日 期 、 上 次 登录 时 间 、 登 录 次 数 以 及 执行 安全 退出 操作 。 用 户 个 人 信息 模块 的 
运行 效果 如 图 2.13 所 示 。 


莫 融 的 ; nr 您 的 身价 : 管理 员 ” 当 市 日 期 为 : 2011 年 02 月 23 日 上 次 登录 时 间 : 2011-02-22 01:34:47 当前 为 第 89 次 登录 甘于 汪 


图 2.13 个 人 信息 显示 
2.5.2 ”用户 个 人 信息 模块 技术 


在 用 户 个 人 信息 模块 中 ， 以 SESSION 变量 中 存储 的 用 户 ID 为 条 件 ， 从 用 户 信 息 表 中 
查询 出 用 户 信 息 ， 并 且 将 用 户 信 息 在 该 页 面 中 输出 。userinfo.php 的 代码 如 下 : 
代码 位 置 ， 配套 资源 \mr\02\userinfo.php 


01 <?php 
02 session startO; // 初 始 化 SESSION 变量 
03 include once("conn/conn.php"): // 包 含 配置 文件 


04 ”/* 查 找 用 户 资料 */ 

05 S$sqlstrvi="select* from tb_meeting_user where userId=$_SESSION[id]"; /执行 查询 操作 
06 $1_Ist=$conn->Execute($sqlstrvi):; 

07 echo $i rst->fields[1]; // 输 出 查询 结果 
108 过 


2.5.3 用 户 个 人 信息 模块 实现 过 程 
当 用 户 正常 登录 俊 羽 会 议 管理 系统 时 ， 系 统 会 根据 SESSION 变量 存储 的 用 户 ID 值 ， 
获取 用 户 的 相应 信息 ， 并 且 完 成 用 户 个 人 信息 的 输出 ， 其 关键 代码 如 下 : 
代码 位 置 ， 配 套 资源 \mr\02\userinfo.php 
01 <?php 


02 Ssqlstrvi="'select * from tb_meeting_user Where userId=$_SESSION[id]"; 
03 $i_Ist=$conn->Execute($sqlstrvi); 


04 > 

05 <table cellpadding="0" cellspacing="0" border="0"> 

06 <tr> 

07 <td width="58" align="center"> 尊 敬 的 ，</td> 

08 <td width="48" align="left"><?php echo $i 1st->fields[1]: ?></td> 

09 <td width="68"> 您 的 身份 : </td> 

10 <td width="78" align="left"> 

WE <?php 

12 ifSi_rst->fields[S] 一 0) /独断 用 户 权限 

13 echo "<span style=\"color:#CC99FF\"> 普 通用 户 </span>"; 

14 else if(Si_rst->fields[5]=—1) 

15 echo "<span style=\"color 考 F0000\V> 管 理 员 </span>": 

16 ?></td> 

17 <td> 当 前 日 期 为 : <span class="dates"><?php echo date("Y 年 mm 月 d 日 ):?></span> 
&nbsp;</td> 
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<td width="78"> 上 次 登录 时 间 :</td> 
<td width="138"> 
<2php // 判 断 用 户 是 否 为 首次 登录 
if($i_rst->fields[4]=—D){ 
echo "-—-——"; 
Jelse{ 
echo $_SESSION["lasttime"]; 
} 
I 
</td> 
<td width="40" > 当前 为 </td> 
<td width="100" align="left"> 第 &nbsp;<?php echo $i_rst->fields[4]; ?>&nbsp; 次 登录 </td> 
<1--<td width="51"><a hre 全 "logout.php"> 退 出 登录 </a></td>--> 
<td width="51"><a href="logout.php"> 
<img strc="images/over3 .png" width="49" height="19" border="0" onclick= "logout0" /</a></td> 
</tr> 
</table> 


值得 一 提 的 是 ， 该 模块 输出 的 上 次 登录 时 间 ， 并 非 直 接 通 过 查询 数据 库 中 相关 字段 的 
内 容 获 取 而 来 ， 该 数据 是 从 SESSION 变量 存储 的 lasttime 中 获得 的 。 


2.5.4 安全 退出 


当 用 户 需要 离开 网 站 时 ， 可 以 单 击 “安全 退出 ” 超 链接 来 调用 logout0 函 数 ， 当 用 户 
确认 退出 后 ， 则 跳 转 到 logout.php 页 面 ， 销 毁 session 并 回 到 首页 。 安 全 退出 所 涉及 的 页 面 


及 代码 如 下 : 


代码 位 置 ， 配 套 资源 \mr\02\userinfo.php 


01 
02 


03 


04 


05 
06 


function logoutO{ 
这 confirm(" 确 定 要 退出 登录 吗 ? ")){ 
// 输 出 选择 框 ， 用 户 可 以 单 击 “ 确 认 ” 或 “取消 ”按钮 
Window.open('logout.php',"_parent',",false); 
// 如 果 用 户 确认 退出 ， 则 打开 logout.php 页 
}else 
return false; 
} 


代码 位 置 ， 配套 资源 \mr\02\logout.php 


01 
02 


<?php 
session_start(); // 开 启 session 支持 
session_destroy0; /销毁 session 
echo '<script>alert(\' 用 户 已 安全 退出 \);location=(\index.php\);</script>"; 
// 回 到 首页 
> 
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2.6 会 议 记 录 添 加 模块 


2.6.1 会 议 记录 添加 模块 概述 


正常 登录 系统 之 后 ， 每 一 个 用 户 都 有 权利 添加 新 的 会 议 ， 供 本 部 门 成 员 和 其 他 部 门 成 
员 阅 读 浏览 ， 本 系统 中 会 议 记录 添加 模块 的 运行 结果 如 图 2.14 所 示 。 | 


二 加 会 识 记录 


ES 73 本 会议 记录 名称 
rm 3* 池 酸 兰 和 会 议 硬 站 
E23 -博信 地 点 名 称 


[ra [La [THs sara 


人 计量 理 -起 会 于 行人 
iie 录 人。 。 地 答 有 < 寺 忆 = 让 子 人 


及 人员。 。 全 人 员工 “起 5 会 识 出 席 人 员 
LRA lemmts md NR sr 


各 于 ZL0 年 工作 司 责 司 1 
会 议和 要 记录 和 要 
习 


ma 


图 2.14 会 议 记录 添加 页 面 | 
2.6.2 会 议 记 录 信 息 验 证 技术 
向 数据 库 中 添加 新 会 议 记 录 时 ， 系 统 必 须 保证 用 户 提交 的 信息 不 为 空 。 这 里 应 用 
JavaScript 脚本 判断 上 传 数据 是 否 为 空 ， 在 js 文件 夹 下 创建 add_meeting.js 文件 ， 编写 
check _submit() 方 法 ， 验 证 表单 提交 的 数据 是 否 为 空 。 其 关键 代码 如 下 : 
代码 位 置 ， 配套 资源 \mr\02\js\add_meeting.js 
01 。 function check submitO{ 


02 if(theForm.meeting name.value—""){ | 
03 alert(" 会 议 名 称 不 能 为 空 ! "):theForm.meeting_name.focus():return false; | 
04 
05 if(theForm.meeting place.value—""){ | 
06 alert(" 会 议 地 点 不 能 为 室 ! ");theForm.meeting place.focusO:retum false; | 
07 } | 
08 这 theForm_meeting hostvalue 一 ""){ | 
09 alert(" 会 议 主持 人 不 能 为 空 ! ");theForm.meeting_host.focus(:return false; | 
10 } | 
11 if(theForm.meeting saver.value—""){ | 
网 alert(" 会 议 记 录 人 不 能 为 空 ! "):theForm.meeting_saverfocusO:retum false; | 
13 } | 
14 if(theForm meeting present.value—""){ | 
15 alert(" 出 席 人 员 不 能 为 空 ! "):theForm.meeting_present.focus():return false: | 
16 和 | 
好 if(theForm.textarea.value—""){ 
18 alert(" 会 议 摘要 不 能 为 空 ! "):theForm.textarea.focus():return false; | 
19 } | 
20 theForm.submitO: | 
2 | 
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2.6.3 ”上传 文 件 处 理 技术 


本 系统 要 求 用 户 在 上 传 会 议 记 录 的 同时 ， 必 须 上 传 文本 文档 格式 的 会 议 记 录 附 件 。 所 
以 又 增加 了 上 传 文件 和 判断 上 传 文件 格式 两 项 技术 。 


1. move_uploaded fileO 函 数 和 $_FILES[] 全 局 变量 


文件 上 传 应 用 的 是 move_uploaded file0 函 数 和 $_FILES[] 全 局 变量 。 
(1) move_ uploaded file(0) 函 数 
move_uploaded_file() 函 数 将 文件 上 传 到 服务 器 中 指定 的 位 置 。 如 果 成 功 ， 返 回 True; 
否则 ， 返 回 False。 语 法 如 下 : 
bool move_uploaded file ( string filename, string destination ) 


其 中 ， 参 数 包 ename 指定 上 传 文件 的 临时 文件 名 ， 即 $_FILES[tmp_name]; 参数 
destination 指 文件 上 传 后 保存 的 新 路 径 和 名 称 。 


说 明 : 

如 果 参 数 filename 不 是 合法 的 上 传 文件 ， 不 会 执行 任何 操作 ，move_uploaded file() 将 
返回 FALSE; 如 果 参 数 filename 是 合法 的 上 传 文件 ,但 出 于 某 些 原因 无 法 移动 ， 同 样 也 不 
会 执行 任何 操作 ，move_uploaded file0 将 返回 FALSE。 此 外 ， 还 会 发 出 一 条 警告 。 


(2) $ FILES[] 全 局 变量 

对 上 传 文件 进行 判断 应 用 的 是 全 局 变量 $_ FILES[]，$_FILES[] 是 一 个 数组 ， 包 含 所 有 
上 传 的 文件 信息 。$_FILES[] 数 组 中 每 个 元 素 的 含义 如 表 2.1 所 示 。 
表 2.1 $_FILES[ 数 组 中 元 素 的 含义 

说 了 明 

存储 上 传 文件 的 文件 名 。 如 texttst、titlejpg 等 
存储 文件 大 小 。 单 位 为 字 节 
存储 文件 在 临时 目录 中 使 用 的 文件 名 。 因 为 文件 在 上 传 时 ， 首 先 要 将 
其 以 临时 文件 的 身份 保存 在 临时 目录 中 
存储 上 传 文件 的 MIME 类 型 ，MIME 类 型 规定 各 种 文件 格式 的 类 型 。 每 种 
MIME 类 型 都 是 由 “/” 分 隔 的 主 类 型 和 子 类 型 组 成 。 例 如 ，image/gi 的 主 
类 型 为 图 像 ， 子 类 型 为 GIF 格式 的 文件 ，texthtml 代 表 文 本 的 HTMI 文 件 
存储 与 文件 上 传 相关 的 错误 代码 。 此 项 目 是 PHP 4.2.0 版 本 中 新 增 内 
容 ， 其 返回 值 有 5 种 ， 如 下 所 示 : 
0: 表示 没有 任何 错误 ， 文 件 上 传 成 功 
1: 表示 上 传 文件 的 大 小 超出 了 PHP 配 置 文件 指令 upload_max_filesize 
选项 限制 的 值 
2: 表示 上 传 文件 大 小 超出 了 HTML 表 单 中 MAX_FILE_SIZE 选 项 所 指 
定 的 值 
3: 表示 文件 只 被 上 传 了 一 部 分 
4: 表示 没有 上 传 任何 文件 


$_FILES[filename][tmp_name] 


$_FILES[filenamej[type] 


$_FILES[filenamel][error] 
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在 $_ FILES[] 数 组 元 素 中 ， 最 为 常用 的 是 $ FILES[filename][name]、$_FILES[filename] 
[size] 和 $_FILES[filename][tmp name]。 通 过 这 3 个 元 素 值 完 成 上 传 文件 名 称 的 获取 ， 判 断 | 
上 传 文件 的 格式 (根据 上 传 文件 名 称 的 后 级 ) 和 大 小 。 | 


2. 自 定义 函数 f postfix() 


上 传 文件 格式 判断 ， 应 用 自 定义 函数 £ postfix0 来 完成 。 在 该 自 定义 函数 中 应 用 到 如 
下 PHP 函数 。 | 
(1) split0 函 数 | 
split0 函 数 使 用 了 Perl 兼容 正则 表达 式 语法 ， 通 常 是 比 explode0 更 快 的 替代 方案 。 如 | 
果 不 需 要 正则 表达 式 的 威力 ， 则 使 用 explode0 更 快 ， 这 样 就 不 会 招致 正则 表达 式 引 擎 的 浪 | 
费 。 相 关 语 法 如 下 : | 
array split ( string pattern, string string [, int limit] ) | 
该 函数 利用 正则 表达 式 将 字符 串 分 隔 到 数组 中 。 它 返回 一 个 字符 串 数 组 ， 每 个 元 素 为 | 
string 经 区 分 大 小 写 的 正则 表达 式 pattem 作为 边界 分 隔 出 的 字 串 。 如 果 设 定 limit 参数 ， 则 | 
返回 的 数组 最 多 包含 limit 个 元 素 。 最 后 一 个 单元 包含 了 string 中 剩余 的 所 有 部 分 。 如 果 出 | 
错 ， 则 返回 False。 | 
(2) count0 函 数 
count0 函 数 的 作用 是 计算 数组 的 元 素 个 数 。 相 关 语 法 如 下 : 
int count ( mixed var [, int mode] ) 
该 函数 返回 var 中 的 单元 数目 ， 通 常 是 一 个 数组 ， 任 何其 他 类 型 都 只 有 一 个 单元 。 
(3) strtolower0 函 数 | 
strtolowerO 函 数 的 作用 是 将 特定 字符 串 的 所 有 大 写字 母 转换 为 小 写字 母 ， 把 转换 后 的 | 
新 字符 串 作 为 函数 的 返回 值 返回 。 | 
自 定义 函数 f_ postfix0 存 储 于 addmeeting_chk.php 文件 中 ， 其 代码 如 下 : 
代码 位 置 ， 配 套 资源 \mr\02\addmeetimg_chk.php 


01 functionf postfix($f type,$f upfiles){ // 获 取 传 递 的 参数 值 

02 $is_pass = false; 

03 Stmp_upfiles = split("\.",Sf_upfiles); /获取 上 传 文件 的 后 绷 

04 Stmp_num = count(Stmp_upfiles); /统计 返回 值 的 元 素数 量 

05 for(Snum = 0; Snum < count(Sf type);Snum+H){ /循环 读 取 定义 文件 类 型 数组 的 值 

06 if(strtolower(Stmp_upfiles[Stmp_num - 1]) 一 $f_type["Snum"]) ! 

// 完 成 文件 类 型 的 大 小 写 转换 及 判断 | 

07 $is pass= $f type["$num"]; // 获 取 文件 类 型 | 

08 } 

09 retum $is_pass; // 返 回 上 传 文件 的 类 型 

10 } | 
通过 该 自 定义 函数 的 使 用 ， 可 以 实现 对 上 传 文件 类 型 的 判断 ， 当 该 函数 返回 值 为 True | 


时 ， 说 明 上 传 的 文件 符合 规定 的 格式 ， 否则 ， 不 符合 系统 所 规定 的 文件 格式 。 
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2.6.4 会 议 记 录 添 加 模块 实现 过 程 


会 议 记 录 添 加 的 操作 是 通过 addmeeting php 与 addmeeting chk.php 两 个 文件 来 实现 的 。 
具体 实现 过 程 如 下 。 
(1) 在 addmeeting.php 文件 中 ， 创 建 添加 会 议 记 录 信 息 的 表单 ， 通 过 JavaScript 脚本 
对 提交 的 元 素 进行 判断 ， 并 且 设 置 action 属性 值 为 addmeeting_chk.php， 其 关键 代码 如 下 : 
代码 位 置 ， 配 套 资源 \mr\02\addmeeting.php 


01 
02 


19 


22 
23 
24 


</textarea></td> 


25 
26 
27 
28 
29 
30 
31 
3 
33 
34 


<table cellpadding="0" cellspacing="0" border="0"> 
<form id="theForm" name="theForm" action="addmeeting chk.php" method="post" 
onSubmit="return check_submit();" enctype="multipart/form-data"> 
<tr><td colspan="3" height="32"><h1 align="center"> 添 加 会 议 记录 </hl></td></tr> 
<tr> 
<td width="120" height="28"><div align="center"> 会 议 名 称 :</div></td> 
<td><input class="input2" type="text" name="meeting name" /></td> 
<td align="left" width="180" ><span class="sp1">* 填 写 会 议 记 录 名 称 </span></td> 
</tr> 
<!- 省 略 部 分 代码 -> 
<tr> 
<td height="28"><div align="center"> 出 席 人 员 :</div></td> 
<td><input class="input2" type="text" name="meeting_present" /></td> 
<td align="left" width="180"><span class="sp1">* 填 写 会 议 出 席 人 员 </span></td> 
</tr> 
<tr> 
<td height="28"> 上 传 会 议 内 容 </td><td> 
<input class="upload" name="meeting documents" type="file" size="16"></td> 
<td align="left" width="180"><span class="sp1">* 上传 TXT 格式 会 议 文稿 </span></td> 
</t> 
<tr> 
<td ><div align="center"> 会 议 摘 要 :</div></td> 
<td height="70"> 
<textarea style="width:170px; border:lpx solid #CCCCCC"name="textarea" rows="4"> 


<td align="left" width="180"><span class="sp1">* 填 写 会 议 记 录 摘 要 </span></td> 
</t> 
<tr> 
<td height="12"colspan="3"></td> 
</tr> 
<tr> 
<td height="30" colspan="2"><center><input class="add mbtnl" type="submit" value=""/>; 
<input class="add mbtn2" type="reset" value="" /></center></td><td></td> 
</t> 
</form></table> 


(2) 创建 addmeeting_chk.php 文件 ， 获 取 表 单 提交 的 数据 。 首 先 ， 定 义 自 定义 函数 用 
于 验证 上 传 文件 的 格式 。 然 后 ， 对 上 传 文件 进行 验证 操作 。 最 后 ， 通 过 move_upload file() 
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函数 执行 文件 的 上 传 操 作 ， 并 且 将 会 议 记 录 添 加 到 指定 的 数据 表 中 ， 其 关键 代码 如 下 : | 
代码 位 置 : 配套 资源 \mr\02\addmeeting_chk.php 


25 $sqlstrii="insert into tb_meeting_info(meeting name,meeting department,meeting place, 

26 meeting_date,meeting host,meeting saver,meeting present,meeting abstruct,meeting address) 

27 values($ POST[meeting name]''$ POST[department]','$ POST[meeting placel','$date','$ 
POST[meeting host]', 

28 '$_POST[meeting saver]','$ POST[meeting present]','$ POST[textarea]','$filepath")"; 


01 <?php | 
02 session start(); | 优 
03 include_once("conn/conn.php"); | 
OY fin re Yi / 济 断 上 传 格式 是 否 符合 上 传 要 求 
05 $is_pass = false; | 
06 Stmp_upfiles = split("\.",SfE_upfiles); | 
07 Stmp_num = count(Stmp_upfiles); | 
08 for($num = 0; $num < count($f type);$num++){ | 
09 if(strtolower(Stmp_upfiles[Stmp_num - 1]) == Sf_ type["Snum'"]) | 
10 $is_pass = $f type["$num'"]: | 
11 } | 
12 Teturn $is_pass; | 
13 } | 
14 if($_FILES["meeting documents"]["size"]<=0){ // 判 断 是 否 上 传 了 文件 | 
15 echo "<script>alert( 请 上 传 文件 ):history.go(-1):</scripf>"; | 
16 }else{ | 
17 Sf type=array("txt"); // 定 义 上 传 文件 的 格式 | 
18 Srecord_path="upfile"; // 定 义 上 传 路 径 | 
19 if((Spostf =f postfix($f_type,$_FILES["meeting_documents"]["name"])) ‘= false){ | 

1/ 判断 上 传 格式 | 
20 Snew_path =time0.".txt": /以 时 间 戳 定义 上 传 文件 名 称 | 
2 if($_FILES["meeting_documents"]["size"] > 0 and $_FILES["meeting documents"] | 

["size"] < 1000000){ | 
22 /判断 用 户 上 传 文件 大 小 是 否 超过 10M | 
23 $date=$_ POST[b_y]."-".$_POST[b_m]."-"$_POST[b_d]: | 
24 Sfilepath=$record_path."\".Snew_path; // 定 义 新 文件 名 称 | 

/数据 库 操作 命令 | 
29 $a_rst = $conn->execute($sqlstrii); // 执 行 数据 库 插入 操作 | 
30 if(!($a_rst—false)){ // 浏 断 数据 添加 是 否 成 功 | 
31 /上 传 文件 操作 | 
32 move_uploaded file($_FILES["meeting_documents"]["tmp_name"],$record_path. | 

"\".Snew_path); | 
3 echo "<script>alert( 添 加 成 功 ');history.go(-1);</script>"; | 
34 }else{ | 
35 echo "<script>alert( 添 加 失败 ):history.go(-1):</script>": | 
36 } | 
37 }else{ | 
38 echo "<script>alert( 上 传 文件 大 小 超过 1M"):history.go(-1);</script>"; | 
39 } | 
40 }else{ | 
41 echo "<script>alert( 上传 只 支持 \"txt\" 格 式 的 文件 ):history.go(-1);</scripf>"; 
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42 } 
43 上 
44 > 


2.7 浏览 会 议 记 录 模 块 设计 


浏览 会 议 记录 模块 概述 
浏览 会 议 记 录 模 块 可 以 说 是 整个 管理 系统 的 核心 ,其 主要 功能 是 通过 查询 数据 库 的 相 


| 关 数 据 ， 将 会 议 的 各 种 信息 输出 到 浏览 页 面 中 ， 用 户 不 但 可 以 浏览 特定 会 议 的 详情 ， 同 时 


也 可 以 对 会 议 内容 进 行 打印 预览 或 打印 操作 。 同 时 ， 用 户 也 可 将 所 有 会 议 的 信息 以 Excel 
报表 形式 导出 。 浏 览 会 议 页 面 的 运行 结果 如 图 2.15 所 示 。 


会 议 信息 浏览 


会 议 编号 会 议 名 称 部 门 名 称 。 会 议 地 点 会 议 日 期 ”主持 人 出 席 人 员 记录 人 会 议 搞 要 查看 详情 
16 PHP 新 项 目 PP 大 会 议 室 2010-4-2 。 Tonmy Leons Rose Leon 分 配 工作 任务 画 
22 FP 二 次 开发 Fe 大 会 议 室 。 2010-1-1 。 Jeff Leon 有 ike Leon 系统 二 次 开发 EE 


点 此 导出 报表 >>> 
图 2.15 浏览 会 议 页 面 
2.7.2 WebBrowser 打印 技术 


WebBrowser 打印 是 正 浏览 器 内 置 的 浏览 器 控件 , 其 优点 在 于 无 需 用 户 下 载 目标 文件 ， 
且 可 以 支持 客户 端 独 立 完成 目标 文件 的 打印 ， 这 样 可 以 减轻 服务 器 负担 ; 缺点 在 于 对 源 文 
档 的 分 析 操 作 比 较 复杂 ， 并 且 要 对 源 文档 中 要 打印 的 内 容 进 行 约束 。 

应 用 WebBrowser 控件 不 但 可 以 实现 报表 的 打印 功能 ， 还 可 以 进行 其 他 操作 ， 如 刷新 
和 保存 页 面 、 页 面 设置 、 查 看 页 面 属性 等 。 在 开发 中 ， 该 控件 需要 调用 Execwb0 方 法 完成 
上 述 功能 ， 为 Execwb0 方 法 传递 不 同 的 参数 可 实现 不 同 的 功能 ， 具 体 参数 如 下 : 
表示 打印 预览 。 
表示 打印 。 
表示 直接 打印 。 
表示 页 面 设置 。 
打开 页 面 。 
关闭 所 有 打开 的 正 窗口 。 
保存 网 页 。 
查看 页 面 属性 。 
全 选 。 


document.all.WebBrowser.Execwb(7.1): 
document.all. WebBrowser.Execwb(6,1): 
document.all. WebBrowser.Execwb(6.6): 
document.all.WebBrowser.Execwb(8.1): 
document.all. WebBrowser.Execwb!(]1,1): 
document.all. WebBrowser.Execwb(2,1): 
document.all. WebBrowser.Execwb(4.,1): 
document.all.WebBrowser.Execwb(10.,1): 
document.all. WebBrowser.Execwb(17,1): 


document.all. WebBrowser.Execwb(22,1): 
document.all. WebBrowser.Execwb(45,1): 
在 本 项 目 中 封装 两 个 JavaScript 脚本 函数 ， 
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刷新 。 
关闭 窗 体 无 提示 。 
通过 不 同 的 函数 加 载 不 同 的 WebBrowser 


第 4 章 会 议 管理 系统 (PHP+1ADODB+Access 实现 ) 8 


控件 ， 完 成 报表 的 打印 预览 和 打印 操作 。 关 键 代 码 如 下 : 
代码 位 置 ， 配套 资源 \mr\02\printwindow.php 


01 <script> 

02 function printviewO { 

03 document.all. WebBrowserl.ExecWB(7,1) ; /执行 打印 预览 

04 window.close0O: 

05 } | 
06 function printO { | 
07 document .all WebBrowserl. ExecWB(6,1) : /执行 打印 操作 | 
08 window.close(); | 
09 } | 
10 </script> 


11 xmlhttp.send(null); 
12<object ID=WebBrowserl' WIDTH=0 HEIGHT=0 CLASSID=CLSID:8856F961-340A-11D0-A96B- 


O00CO4FD705A2></object> 
13 -<?php 
14 $action=$_ POST["print"]; 
15 ”i 人 $action 一 "打印 预览 "){; // 判 断 前 台 按 钮 操作 
16 ?> 
17 <body topmargin="0" leftmargin="0" bottommargin="0" onLoad="printviewO;"> 
18 <?php 
19  }elseif($action=—" 打 ED"){ 1/ 判断 前 台 按 钮 操作 
20 > 
wj <body topmargin="0" leftmargin="0" bottommargin="0" onLoad="print03;"> 
2 <?php 
23000 
24 > 


2.7.3 “Excel 报表 生成 技术 


Excel 报表 通过 header0 函 数 生成 下 载 文件 ，header0 函 数 属于 HTTP 函数 ， 其 作用 是 
发 送 一 个 原始 的 HTTP 标 头 。headerO 函 数 的 语法 如 下 : 
void header(string string[,bool replace[,int http_response_code]]) 
参数 说 明 如 下 : 
回 string: 发 送 标 头 。 
回 replace: 如 果 一 次 发 送 多 个 标 头 ， 指 明 相 似 的 标 头 是 替换 还 是 添加 。 | 
回 http_ response_ code: 强制 HTTP 响应 为 指定 值 。 | 
生成 Excel 报表 的 关键 代码 如 下 : 
01 <2php | 
02 header("Content-type:application/vnd .ms=excel"); /设置 HITP 标 头 | 
03 ”header("Content-Disposition:filename= 会 议 报表 .xls"); /定义 下 载 文件 名 称 
04 session start():; 
05 ec 
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2.7.4 文本 文件 中 数据 的 获取 技术 


添加 会 议 记 录 过 程 会 添加 一 个 文本 文档 。 在 浏览 会 议 记 录 时 ， 会 通过 数据 库 相 应 的 路 
径 获取 相应 文件 的 内 容 并 显示 在 浏览 页 面 上 。 关 键 代码 如 下 : 


01 $myfile=fopen("$address","r"); /将 文件 以 只 读 方式 打开 
02 。 $myline=fgets(gmyfile): /获取 文 件 内 容 

03 echo $myline; // 输 出 获取 的 文件 内 容 
04 felose($myfile): /关闭 文件 


从 文本 文件 中 读 取 数 据 应 用 的 是 文件 操作 函数 。 相 关 说 明 如 下 : 

回 fopen0 函 数 

该 函数 的 作用 是 打开 本 地 或 者 远程 文件 。 其 中 ， 参 数 filename 为 一 个 字符 型 变量 ， 代 
表 打 开 的 文件 名 称 ; 参数 mode 有 6 个 可 选 模式 ， 分 别 是 r、r+、w、w+、a、a+。 根 据 可 
选 模式 ， 可 对 文件 执行 不 同 的 操作 。 

回 fgets0 函 数 

该 函数 的 作用 是 按 行 返回 文件 内 容 ， 其 语法 如 下 : 

string fgets ( int handle [, int length] ) 

表示 从 handle 指向 的 文件 中 读 取 一 行 并 返回 长 度 最 多 为 length-1 字 节 的 字符 串 。 

回 fclose0 函 数 

该 函数 的 作用 是 关闭 一 个 已 打开 的 文件 指针 , 如 果 成 功 则 返回 True, 失败 则 返回 False。 


2.7.5 浏览 会 议 记 录 实 现 过 程 


会 议 信息 显示 页 面 循环 输出 会 议 的 主要 信息 , 首先 查看 tb_meeting info 数据 表 中 是 否 
有 记录 ， 如 果 数 据 表 中 没有 记录 ， 则 输出 “当前 没有 任何 记录 ” 如 果 数 据 表 中 有 数据 ， 


则 分 页 输出 数据 。 会 议 信 息 显示 页 (viewmeetingphp) 代码 如 下 
代码 位 置 ， 配套 资 源 \mr\02\viewmeeting.php 


01 <?php 

02 $sqlview="select * from tb_meeting info"; 

03 Snum=2; /每 页 显示 最 大 记录 数 

04 ifisset($_GET[m page])){ /判断 当前 页 码 

05 $c page=$_GET[m page']: /将 na page 赋 给 变量 $c_page 
06 }else{ 

07 $c page=1; // 初 始 化 变量 $c_page 

08 } 


09 SL_rst = Sconn -> PageExecute($sqlview,Snum,Sc_page); ”// 执 行 PageExecute0 函 数 
10 $Irst_view = $conn->execute($sqlview): 

ll Srecord=count(Srst_view->GetRows0O); 1/ 获取 总 记录 数 

2 if($record—0){ 

13 ”echo "<span class=\norecord\"> 当 前 没有 任何 记录 </span>": 
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ed 
14 }else{ 
15 > 
16 <table width="728" border="0" cellspacing="0" ce ing="0" bordercolor="#66CC00"> 
17 <!-- 省 略 部 分 代码 --> 
18 </table> 
19 <div class="sepa_page"> 
20 <table> 
21 <tr> 
22 <td> 


23 <font > 当前 是 第 <?php echo $l rst -> absolutePage0; ?> 页 /一 共 <?php echo $l rst -> 
LastPageNo(); ?> 页 </font> 


24 <?php 

25 这 !$L rst -> AtfirstPageO){ /如 果 当 前 页 不 是 首页 

26 > 

27 <a href ="<?php echo "?Imbs=$_GET[Imbs]&n_page=1" ?>"> 首页 </a> 

28 <a href ="<?php echo "?Imbs=$_GET[Imbs]&n_page=".($l_rst -> absolutePage0 - 
TD; ?>"> 上 一 页 </a> 

29 <?php 

30 } 

31 if(!$1 rst -> AtlastPage()){ // 如 果 当 前 页 不 是 尾 页 

32 > 


33 ”<!-- 输 出 向 下 翻 页 超 链 接 --> 
34 <a href = "<?php echo "?Imbs=$ GET[Imbs]&n page=".(Sl_rst -> absolutePage0 + 
> 下 一 页 </s> 


35 <a href ="<?php echo "?Imbs=$_GET[Imbs]é&n_page=".($1_rst -> LastPageNo0);?>"> 
尾 页 </a> 

36 <?php 

37 

38 ?><?php 

39  } 

40 > 

41 </td> 

42 <td width="100"align="right*><span style="color:#FF0000"> 点 此 导出 报表 >>></span> 
</td> 

43 <td width="60"> 


44 <a href="createform.php"><img align="bottom"src="images/out_15.jpe" width="48" height= 
"20" border="0" /></a> 


45 </td> 
46 </tr> 
47 </table> 


2.7.6 会议 记录 详细 信息 浏览 实现 过 程 


对 于 俊 羽 会 议 管理 系统 ， 不 仅 可 以 浏览 会 议 的 主要 信息 ， 同 时 也 可 以 查看 会 议 的 详细 
内 容 ， 阅 读 特 定 的 会 议 内 容 。 会 议 详 细 信息 页 面 的 运行 结果 如 图 2.16 所 示 。 


。53 。 


日 
Ey 


01 


09 


| <h3></td></tr> 


明日 科技 有 限 公 司 会 议 记录 详情 


Rs: 22 EE Hi 
部 站 十 放 : re i Kw 

研 亨 晶 耻 oil RE: Jet 

[TE en me 会 记录 人 : Te 

会 请 要 : 系统 一 次 开发 

WA 

会 训 记 季 管 理 到 二 的 于 项。 开 皮 要 生 : 识 末 加 耻 和 打印、 支持 31CEL 导出 ，PHEHeress。 开 帮 由 容 : 会 


议 洁 息 估 括 辣 议 扩 号 、 会 设 各 禾 ， 部 各 称 ， 会 议 地 点 等 古 信息 。 切 能 村 孙 ; 过 加 全 议 记录 ; 浏览 所 有 


会 这 记录 ; 合议 扩 号 和 全 议和 查 鹿 会 识 记录 ; 修 队 六 记录。 


图 2.16 


<2php 
$id=$_GET["id"]; 


ET 


EE 


会 议 详细 信息 页 面 运行 结果 

| 创建 showinfo.php 文件 ， 根 据 GET 方法 传递 id 值 ， 查 询 数 据 库 中 数据 ， 返 回 查 询 结 
| 果 ， 并 且 通 过 文件 系统 函数 读 取 文 本 文件 中 存储 的 会 议 记 录 内 容 ， 其 代码 如 下 : 

代码 位 置 ， 配套 资源 \mr\02\showinfo.php 


// 获 取 传 递 的 i 值 


$sqlstriii="select * from tb_meeting_info where meeting_id =S$id";  ”// 数 据 库 查 询 语句 
$s_Ist=$conn->Execute($sqlstriii); 


> 
<div class="infoshow"> 


/执行 查询 操作 


<table width="560" border="0" cellspacing="0" cellpadding="0"> 


<form action="printwindow.php" method="post"> 


<tr><td colspan="4" align="center"><h3 class="ht"> 明 日 科技 有 限 公司 会 议 记 录 详 情 


<tr> 


<td width="134"><div align="right"> 会 议 编号 ;</div></td> 
<td width="340"><?php echo $s_rst->fields[0]?></td> 
<td width="135"><div align="right"> 会 议 名 称 : </div></td> 
<td width="341"><?php echo $s rst->fields[1]9></td> 


</tr> 
<!-- 省 略 部 分 代码 --> 
<tr> 
<td height="200" col 
<div class="content"> 


<2php 


an="4"> 


Saddress=$s_rst->fields[9]; 
Smyfile=fopen("S$address","r"); 
Smyline=fgets(Smyfile); 


echo $myline; 
fclose($myfile); 
> 
</div> 
</td> 

</t> 


// 获 取 文件 路 径 及 文件 名 称 
/将 文件 以 只 读 形式 打开 
/获取 文件 中 的 内 容 
/输出 文件 内 容 

/关闭 文件 


第 2 章 会 议 管 理 系统 (PHPHQDODB+access 实现 ) § 


Rp 

30 <tr> | 

31 <td colspan="4" align="center"><input type="hidden" name="id" value="<?php echo | 
$id; ?>"/></td> | 

32 </tr> 

33 </table> 

34 </div> 

35 <div class="printbutton"> 

36 <input ”type="submit" value=" 打 印 预览 " name="print" /> 


37 &nbsp;&nbsp; 
38 <inputtype="submit" value=" 打 印 " name="print" /> 
39 </form> 


2.8 ”查找 会 议 记 录 模 块 设计 


2.8.1 查找 会 议 记录 模块 概述 


当 添 加 的 会 议 记 录 太 多 时 ， 逐 条 查找 对 于 使 用 者 来 说 是 一 件 十 分 困难 的 事情 ， 这 时 用 | 
户 可 以 通过 “查找 会 议 记 录 ” 超 链接 切换 到 会 议 记 录 查 找 页 面 ， 输 入 查询 内 容 并 选择 查找 | 
方式 之 后 ， 单 击 “ 查 询 ” 按 钮 即 可 对 特定 的 会 议 记录 进行 搜索 查询 。 查 找 会 议 记录 页 面 的 | 
运行 结果 如 图 2.17 所 示 。 | 


查找 会 议 记录 
查询 内 容 : 年 会 


查找 类 型 : [会 充 吾 称 了 


图 2.17 查找 会 议 记 录 页 面 运行 结果 


2.8.2 分 类 查找 技术 


在 查找 会 议 记 录 模 块 中 ， 需 要 选择 查找 类 型 对 数据 进行 分 类 查找 。 在 后 台 获 取 类 型 传 
递 值 ， 通 过 if 判断 语句 执行 不 同 的 查询 操作 ， 并 将 查询 的 结果 集 输出 到 查询 结果 显示 页 | 
showphp 文件 中 。 关 键 代码 如 下 所 示 : | 

代码 位 置 : 配套 资源 \mr\02\show.php 

01 <?php 

02 session start(); 

03 include_once("conn/conn.php"); 
04 $char=$_POST["characters"]; 
05 $type=$_POST["findtype"]; 


06 if($type—0){ 

07 echo "<script>alert(' 请 选择 查找 类 型 ! ");history.go(-1);</script>"; 

08  }elseif($type—1){ | 
09 $sqlstrv="'select * from th_meeting_info where meeting id=Schar"; // 按 会 议 编号 查找 | 


10 }else if($type—2){ 
i 人 加 


| 
1E2 
14 
3 
16 
17 


人 Pitp 项 目 娄 们 分 析 


Ssqlstrv="'select * from tb_meeting_info where meeting_name like '%".Schar."%""; 
/ 按 会 议 名 称 查 找 
} 
S$rst_find = $conn->execute($sqlstrv); 
Srecord=count(Srst_find->GetRows(); 
这 $record 一 0){ 
echo "没有 匹配 的 查询 结果 !"; 
} 


2.8.3 ”查找 会 议 记录 实现 过 程 


查找 会 议 记录 功能 是 通过 表单 提交 的 关键 字 来 查询 的 ,将 符合 条 件 的 查询 结果 作为 返 


回 结果 输出 。 
见 过 程 如 下 : 


分 类 查找 功能 由 查找 页 found.php 和 显示 页 show.php 两 个 文件 组 成 。 具 体 实 


(1) 在 found.php 文件 中 , 创建 表单 ,提交 会 议 记 录 的 查找 关键 字 ， 其 关键 代码 如 下 : 


代码 位 置 : 


01 
02 
03 


配套 资源 \mr\02\found.php 


<form id="found" name="found" action="managerphp?lmbs= 查 找 会 议 结果 " 
method="post" onSubmit="return check_submit0"> 
<tr><td height="26"> 查 询 内 容 : </td><td><input class="input_found"name="characters" 


type="text" /></td></tr> 


value="" /></td> 
15 
16 


<tr> 

<td height="26"> 查 找 类 型 :</td> 

<td align="left"> 

<select name="findtype"> 
<option value="0"><- 查 找 类 型 -></option> 
<option value="1"> 会 议 编号 </option> 

<option value="2"> 会 议 名 称 </option> 

</select> 

</td></tr> 

<tr> 

<td height="26" colspan="3" align="center"><input class="found btn" type="submit" 


</tr> 
</form>} 


说 明 : 


上 述 代码 同样 调用 了 JavaScript 脚本 来 判断 输入 的 查询 内 容 是 否 为 空 。 


(2) 创建 show.php 文件 ,根据 表单 提交 的 关键 字 执 行 查询 操作 ， 并 且 输 出 查询 结果 ， 


其 关键 代码 如 
代码 位 置 : 


01 
02 
03 


下 : 
配套 资源 \mr\02\show.php 


<2?php 
session start(); 
include_once("conn/conn.php"); 
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Ss 
04 $char=$ POST["characters"]; /将 POST 传递 参数 赋值 给 变量 
05 $type=$ POST["findtype"]: 
06 if($type—0){ // 判 断 是 否 选 择 查 找 类 型 
07 echo "<script>alert( 请 选择 查找 类 型 ! "):history.go(-1);</script>"; 
08  }elseif($type—1){ | 
09 S$sqlstrv="select * from tb_meeting info where meeting_id=Schar"; / 按 会 议 编号 查找 | 
10 J}elseif($type—2){ | 
11 Ssqlstrv="'select * from tb_meeting_info where meeting_name like '%".Schar."%""; 
// 按 会 议 名 称 查 找 
1> 
13 S$rst_find = $conn->execute($sqlstrv); 
14 Srecord=count(Srst find->GetRowsO); // 查 找 返 回 数量 
15 if($record=—=0){ /判断 是 否 存在 相应 记录 


16 ”echo "没有 匹配 的 查询 结果 !"; 


1 }else{ 
18 ?> 


19 ”<h3> 会 议 信息 浏览 </h3> 
20 <table width="730" border="0" cellspacing="0" cellpadding="0"> 


21 <tr class="tableheader"> 

22 <td width="50"> 会 议 编号 </td> 
23 <!-- 省 略 部 分 代码 --> 

24 <?php 

25 while(!Srst_find->EOF){ 

26 ?> 

27 <tr> 

28 <td height="22"><?php echo S$rst_find->fields[0]; ?></td> 
29 <!-- 省 略 部 分 代码 --> 

30 <?php 

3 Srst_find->movenext0; 

32 } 

| > 

34 </table> 

35 <2php 

36 } 

37 es 


说 明 : 


在 俊 羽 会 议 管理 系统 中 ， 还 包括 用 户 账户 管理 、 会 议 信息 管理 和 部 门 管理 等 模块 。 由 
于 篇 幅 限制 和 功能 的 重复 ， 这 里 不 再 次 述 ， 其 完整 代码 请 参考 本 书 配套 资源 。 


2.9 ADODB 连接 数据 库 技 术 专 题 


PHP 为 各 种 版 本 的 数据 库 定 义 了 庞大 的 函数 群 来 支持 ， 而 且 支 持 得 很 完整 ， 那 为 什么 
本 系统 要 使 用 ADODB 来 对 数据 库 进行 操作 呢 ? 原因 在 于 ADODB 的 优势 : 一 次 编写 ， 不 


需 修改 。 也 就 是 说 ， 当 系统 使 有 


的 数据 库 需 要 更 换 时 ， 只 要 更 新 数据 库 、 数 据 表 即 可 ， 不 


。57 。 
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a 
需要 重新 编写 源码 ， 这 为 后 期 维护 节约 了 一 大 笔 开销 ， 而 且 不 需要 长 时 间 关 闭 网 站 ， 这 是 
PHP 函数 所 无 法 比拟 的 。 


2.9.1 ADODB 简介 


由 于 PHP 存 取 函 数 没有 标准 化 ,不 同 数据 库 间 的 函数 名 称 、 参 数 差异 很 大 , 在 更 换 数 
据 库 时 ， 会 带 来 大 量 的 代码 修复 工作 。 这 时 ， 就 需要 一 组 函数 库 来 隐藏 不 同 资料 库 函 数 界 
面 间 的 差异 ， 让 开发 者 可 以 很 简单 地 去 切换 资料 库 ， 这 就 是 ADODB。ADODB 目前 支持 
MySQL、 Oracle、Microsoft SQL Server、Sybase、PostgreSQL、Foxpro、Access、ADO 和 
ODBC 等 大 多 数 数据 库 类 型 。 


2.9.2 ADODB 的 安装 


要 使 用 ADODB 来 操作 数据 库 ， 首 先 就 要 获取 和 安装 ADODB。 读 者 只 要 到 网 上 下 载 
ADODB 包 ， 解 压 到 Web 服务 器 目录 下 即 可 。 


注意 : 

要 使 用 ADODB， 使 用 的 PHP 必须 是 4.01 以 上 的 版 本 。 
2.9.3 ADODB 常用 函数 及 说 明 

下 面 介绍 ADODB 中 的 常用 函数 和 常量 。 

1. PConnect($host,$user,$password, $database) 

参数 说 明 如 下 : 

回 $host 数据 库 服务 器 地 址 。 

回 $user: 数据 库 用 户 名 。 

回 $password: 数据 库 密码 。 

回 $database: 连接 的 数据 库 。 

如 果 连 接 成 功 回 传 TRUE;， 失败 则 回 传 FALSE。 

2. SelectLimit($sql,$numrows=-1,$offset=-1) 

参考 说 明 如 下 : 

回 $sql: 执行 的 SQL 语句 。 

回 $numrows: 显示 的 记录 条 数 。 

回 $offset， 从 第 几 条 记录 开始 计算 。 

该 函数 和 MySQL 里 的 limit 子 句 相 似 ,但 要 注意 ,limit 后 面 的 两 个 参数 的 顺序 是 offset、 
numrows， 与 该 函数 是 完全 相反 的 。 


3. ErrorMsg() 
ErrorMsg0 函 数 用 于 回 传 错 误 信 息 。 当 execute0 函 数 出 现 错误 时 ,使 用 ErrorMsg0 函 数 
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可 以 查看 最 后 出 错 的 相关 信息 。 使 用 方法 如 下 : 


S$recordset = $conn->Execute("select * fom tb_audio") 

这 !$recordseb) // 判 断 execute0 函 数 执行 中 是 否 有 错误 
echo $conn->ErmorMsg0O: 

else{ 


} | 
即使 没有 出 现 错误 ，ErrorMsg0 也 会 回 传 最 后 的 状态 值 ， 这 种 情况 下 一 般 不 需要 输出 。| 
4. RecordCount() | 
RecordCount0 函 数 用 于 回 传 结果 集 里 的 记录 数 。 使 用 方法 如 下 : 


$sql = 'select * from tb_account'; 
$rs = $conn->Execute($sq]); // 执 行 SQL 语句 
echo $rs->RecordCount(); /| 输出 查询 结果 数 


5. FieldCount( ) 
FieldCount0) 函 数 用 于 回 传 结果 集 里 的 字段 数 。 使 用 方法 同 RecordCountO。 
6. MoveNext()、 Move($to).、 MoveFirst()、MoveLast() 


这 4 个 函数 的 作用 分 别 如 下 : 

MoveNext(): 移动 指针 到 下 一 条 记录 。 | 

Move($to): 移动 指针 到 指定 的 列 ($to)。 这 里 使 用 的 是 绝对 定位 ， 如 S$to 是 10， 1 

移动 到 结果 集中 的 第 10 条 记录 ， 如 果 $to 大 于 记录 总 数 ， 指 针 将 移动 到 最 后 。 

意 ， 部 分 数据 库 不 支持 向 后 移动 指针 。 

MoveFirst0: 实际 上 就 是 Move(0)， 指 针 移 动 到 结果 集 头 部 ， 部 分 数据 库 不 支持 该 
函数 。 

MoveLast(): 指针 移动 到 结果 集 的 尾部 ， 也 可 以 表示 为 Move($recordCount(0-1)， 
部 分 数据 库 不 支持 此 函数 。 


7. SADODB FETCH MODE 


该 常量 决定 了 结果 集 以 哪 种 方式 将 数据 回 传 ,在 有 些 数据 库 中 ， 使 用 Srecordset->fields[] 
仅 支 持 字 段 编号 为 索引 ， 即 0、1、2 等 ， 不 支持 字段 名 (如 id、user) 做 索引 ， 这 时 ， 可 | | 
以 使 用 该 常量 进行 设置 ， 该 常量 的 值 有 : | 


| 


define( ADODB FETCH DEFAULT'.0): // 系 统 默 认 值 

define( ADODB FETCH NUM'.1): // 以 字段 编号 为 索引 
define( ADODB FETCH ASSOC'2): // 以 字段 名 称 为 索引 
define( ADODB FETCH BOTH',3): // 同 时 用 编号 和 名 称 


(了 ip 项 目 业 全 分析 


| 有 了 $ADODB FETCH MODE 常量 ， 可 以 任意 指定 结果 集 以 哪 种 方式 将 数据 回 传 。 
| 例如 ， 在 下 面 的 代码 中 设置 8ADODB FETCH MODE 的 值 为 ADODB FETCH ASSOC， 
| 以 字段 名 称 为 索引 返回 结果 集 。 


入 大 | $conn = &ADONewConnection("mysq"): 
$conn->PConnect("db_online"); 


$ADODB FETCH MODE = ADODB FETCH ASSOC: 
S$recordset = $conn->Execute("select * from tb_audio"); 


if(!$recordset) /判断 execute0 函 数 执行 中 是 否 有 错误 
echo $conn->ErrorMsg(); 
else{ 
while(!S$recordset->EOF){ // 如 果 没 有 错误 ， 则 配合 wihle 语句 循环 输出 结果 
echo $recordset->fields[id]."<br>"; 
S$recordset->movenext(): // 指 针 下 移 
} 
} 


| 这 里 建议 将 SADODB_FETCH_MODE 的 值 固 定 为 ADODB FETCH NUM 及 ADODB_ 
| FETCH_ASSOC， 不 建议 使 用 ADODB_FETCH_BOTH， 因 为 许多 驱动 程序 并 不 支持 该 


| 常量 。 
| 关于 ADODB 的 常用 函数 介绍 至 此 ， 如 果 读 者 感 兴趣 ， 可 以 下 载 ADODB 手册 来 学 习 
| 更 多 内 容 。 


2.9.4 不 同 数据 库 之 间 的 转换 


| 使 用 ADODB 的 优势 在 于 可 以 在 以 后 的 升级 中 , 更 换 不 同 的 数据 库 而 不 用 大 量 改 动 源 
| 程序 。 但 不 同 数据 库 之 间 ， 有 的 SQL 语句 或 语法 是 不 相同 的 ， 这 时 就 要 做 一 些 调整 。 
(1) 在 conn.php 文件 中 ， 更 改 连接 的 数据 库 类 型 和 参数 


有 如 下 链接 语句 : 
$conn = &ADONewConnection(mysql)): /建立 MySQL 连接 
$conn->PConnect("localhost", "root","111","db_online"): // 连 接 db_online 数据 库 


使 用 SQL Server 时 ， 上 面 的 链接 语句 更 改 为 : 
$conn = &ADONewConnection(mssql): 
$conn->PConnect("localhost","sa","","db_online"); 
(2) 注意 包含 时 间 类 型 的 SQL 语句 
不 同 的 数据 库 对 于 时 间 的 表述 是 不 同 的 ， 如 MySQL 使 用 时 间 类 型 时 ， 就 像 使 用 字符 
| 类 型 一 样 ， 放 到 单 引号 里 即 可 ， 但 Access 则 需要 放 到 “#” 之 间 。Oracle 虽然 也 是 使 用 单 
| 引 叶 ， 但 格式 为 “日 -月 -年 ” 而 其 他 数据 库 大 多 都 是 “年 -月 -日 "。 
(3) 尽量 使 用 通用 的 SQL 语句 
尽管 国际 标准 化 组 织 〈ISO) 在 1987 年 创建 了 SQL 的 一 个 标准 ， 但 在 各 种 SQL 之 间 
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仍然 存在 差别 。 所 以 为 了 增加 通用 性 ， 最 好 了 解 一 下 数据 库 间 的 不 同 。 例 如 ，MySQL 中 | 
的 limit 子 句 ， 在 Oracle 中 就 不 被 支持 。 | 


2.10 项 目 发 布 


1. 搭建 PHP 运行 环境 


由 于 笔者 在 开发 项 目 时 应 用 AppServ 集成 化 安装 包 搭建 的 PHP 运行 环境 ， 所 以 建议 | 
读者 也 应 用 AppServ 来 搭建 PHP 运行 环境 。 这 样 可 以 确保 项 目 正常 运行 。 | 


2. 具体 项 目 发 布 方法 


发 布 本 项 目的 具体 方法 如 下 : 
(1) 将 程序 文件 夹 02 复制 到 AppServ 安装 后 的 www 文件 夹 下 。 | 
(2) 由 于 本 项 目 采 用 Access 数据 库 ， 操 作 Access 数据 库 使 用 的 是 ADODB。 因 为 
ADODB 属于 第 三 方 组 件 ， 项 目的 配套 资源 源码 中 没有 提供 ， 所 以 需要 读者 手动 下 载 | 
ADODB 类 库 ， 将 其 存储 于 项 目 02/ 文 件 夹 下 ， 并 且 命 名 为 adodb。 


本 章 小 结 


本 章 主要 实现 了 应 用 ADODB 操作 Access 数据 库 技术 ， 对 俊 羽 会 \ 议 管理 系统 的 开发 | 
过 程 进行 了 详细 讲解 。 通 过 本 章 的 学 习 ， 读 者 能 够 掌握 以 下 几 点 内 容 。 | 
(1) ADODB 操作 Access 数据 库 技 术 。 
(2) 文件 上 传 技 术 的 应 用 。 
(3) WebBrowser 打印 技术 。 
(4) Excel 报表 生成 技术 。 


es UD 
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梦幻 网 络 日 记 


( Apache+PHP+ MySQL 实现 ) 
自学 视频 、 源 程序 : 配套 资源 Mnmm3\ 


随 着 科技 的 飞速 发 展 ， 人 们 的 生活 与 学 习 越 来 越 智能 化 。 相 对 地 ， 人 们 的 
压力 也 越 来 越 大 。 人 们 渴望 倾诉 ， 网 络 日 记 的 出 现 ， 在 一 定 程度 上 满足 了 人 们 
的 这 种 愿望 。 通 常 的 网 络 日 记 是 为 用 户 提供 一 个 以 日 记 会 友 的 平台 ， 用 户 之 间 
可 以 就 日 记 的 内 容 相 互 留言 ， 从 而 使 网 络 日 记 也 成 为 了 一 个 相互 交流 的 平台 。 
但 是 ， 这 样 的 网 络 日 记功 能 单一 ， 不 能 满足 人 们 的 其 他 需要 。 梦 幻 网 络 日 记 为 
用 户 提供 了 一 个 “ 单 击 版 ”的 网 络 日 记 ， 在 本 系统 中 ， 用 户 可 以 书写 自己 的 心 
事 ， 记 录 自 己 的 日 常 消费 。 其 独 有 的 网 页 阅 钟 功能 ， 能 为 用 户 提供 一 个 “私人 
小 秘书 "， 让 生活 和 学 习 无 优 。 

通过 阅读 本 章 ， 读 者 可 以 学 到 : 


二 级 导航 菜单 的 设计 

Ajax 无 刷新 操作 

日 期 的 验证 

查询 关键 字 描 红 

通过 JavaScript 实现 批量 删除 


和 总 吾 吾 吾 吾 
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3.1 项 目 设计 思路 


3.1.1 功能 阐述 | 鲜 


梦幻 网 络 日 记 主要 为 用 户 提供 网 页 闸 钟 、 理 财 助手 、 我 的 日 记 以 及 管理 日 记 本 4 个 主 | 
要 模块 。 | 


网 页 闹钟 模块 主要 为 用 户 提供 事务 主题 的 添加 和 查询 以 及 网 页 曾 钟 的 设置 等 功能 。 | 
理财 助手 模块 是 网 络 日 记 的 特有 模块 ， 包 括 收入 和 支出 的 添加 、 财 务 管理 、 了 人 全 | 
以 及 财务 统计 等 功能 。 


我 的 日 记 模块 是 网 络 日 记 的 主要 模块 ， 包 括 日 记 的 添加 、 查 看 、 查 询 以 及 删除 功能 。 
管理 日 记 本 模块 主要 用 于 修改 用 户 登 录 日 记 本 的 密码 。 
3.1.2 系统 预览 


为 了 让 读者 对 本 系统 有 个 初步 的 了 解 和 认识 ， 下 面 给 出 本 系统 的 几 个 页 面 运行 效果 图 。 
用 户 注册 页 面 如 图 3.1 所 示 ， 该 页 面 显示 用 户 注册 时 需要 填写 的 资料 。 


用 户 注 册 


梦幻 的 世界 欢迎 你 ! 


用 户 眠 称 : 小米 


密 保 问题 : 。 今天 的 天 气 好 吗 9 | 
密 保 答 案 : 好 


攻 到 。 匡 引 


图 3.1 用 户 注册 页 面 


网 页 曾 钟 设置 页 面 如 图 3.2 所 示 ， 该 页 面 用 于 网 页 闹钟 的 设置 , 包括 事务 主题 的 选择 、 
提醒 方式 、 提 醒 时 间 和 提醒 铃声 的 选择 等 。 


温 吉 提示 : 
、 扣 果 关 闭 页 面 ' 同名 村 无 法 稳 竺 。 
2 末次 打开 页 面 ， 先 前 设 定 9 用 钟 仍然 生效 。 
3、 雪 要 打开 部 内 或 催 菜 耳机 ， 以 全 Ff 提示 竺 声 。 
4、 用 钟 以 名 电 及 寻 间 为 礁 ， 请 先 校对 好 本 机 时 间 。 


图 3.2 网 页 闸 钟 设置 页 面 | 
SN L_ 
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| 添加 日 记 页 面 如 图 3.3 所 示 ， 该 页 面 实现 日 记 数 据 的 添加 ， 包 括 文章 主题 、 文 章 内 容 
| 和 用 户 心情 等 。 
sa 


6 图 o 盖 o 袁 0 加 


您 让 9 心 情 : 
5 合 ©@ oo BY ol 
Note 从 二， 天 末了 ， 大 家 而 上 的 心 二， 去 户外 直 老 ， 居 六 导 作 " 该 
松 心 情 。 

| 

| 上 
| 
| 
! 
| 
! 
| 
| 
| 
| 
| 
| 
! 
| 
| 
| 
| 
| 


验 焉 到: 8201 村 
BO@ 
图 33 添加 日 记 页 面 


财务 管理 页 面 如 图 3.4 所 示 ， 通 过 时 间 和 类 别 的 查询 输出 相关 的 收入 和 支出 ， 并 对 其 
进行 修改 和 删除 操作 。 


图 3.4 ”财务 管理 页 面 
3.1.3 功能 结构 
梦幻 网 络 日 记 的 功能 结构 如 图 3.5 所 示 。 


查 
询 
事 
务 
主 
题 


图 3.5 梦幻 网 络 日 记功 能 结构 图 
3.1.4 文件 组 织 结构 
在 进行 网 络 日 记 开发 之 前 ， 要 对 系统 整体 文件 夹 组 织 架 构 进行 规划 。 对 系统 中 使 用 的 


.64 。 
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文件 进行 合理 的 分 类 ， 分 别 放置 于 不 同 的 文件 夹 下 。 通 过 对 文件 夹 组 织 架 构 的 规划 ， 可 以 | 
确保 系统 文件 目录 明确 、 条 理 清晰 ， 同 样 也 便于 系统 的 更 新 和 维护 。 本 项 目的 文件 夹 组 织 | 
结构 规划 如 图 3.6 所 示 。 


日 外 0 一 项 目 根 文件 夫 
白人 cm 


国 addtype. php 

团 affairsquery. php 
国 affairsstat. php 
国 smendcode php 


ce 汗 略 部 分 内 容 


图 3.6 梦幻 网 络 日 记 文件 夹 组 织 结构 


3.2 数据 库 设 计 


3.2.1 数据 库 设计 结构 


结合 实际 情况 及 对 功能 的 分 析 ， 规 划 梦 幻 网 络 日 记 系统 的 数据 库 ， 定 义 数 据 库 名 称 为 | 
db diary， 该 数据 库 主 要 包含 6 个 数据 表 ， 如 图 3.7 所 示 。 | 


胃 服务 器 : localhost ， 电 数据库 : db_diary 
表 整理 


说 明 
th_clock MYSAM gb2312_chinese_ci 网 页 用 钟表 
tb_income MyISAM gb2312_chinese_ci 收入 记录 赤 
th_jour MyISAM gb2312_chinese_ci 日 记 信息 未 


th_motif MYISAM gb2312_chinese_ci 事务 主题 信息 表 
tb_outgo MyISAM gb2312_chinese_ci 支出 记录 表 
tbreg | MyISAM ”gb2312_chinese_cl 用 户 信息 表 


图 3.7 梦幻 网 络 日 记 数 据 库 
3.2.2 ”数据 表 设 计 结构 


梦幻 网 络 日 记 的 数据 库 中 包括 6 张 数据 表 ， 如 表 3.1 一 表 3.6 所 示 。 
1. tb_clock (网 页 阅 钟 表 ) 
网 页 闹钟 表 主 要 用 于 存储 设置 闹钟 的 相关 信息 。 其 结构 如 表 3.1 所 示 。 


二 < 


字段 名 称 数据 类 型 说 明 
辐 | jint | 自动 编号 id 
clocknow | datetime | 曾 钟 时 间 
music | varchar | 曾 钟 铃声 
tsnr | varchar | 提醒 内 容 
tsfs | varchar | 提醒 方式 
control int 控制 闹 铃 是 否 执行 


2. tb income (收入 记录 表 ) 


收入 记录 表 主要 用 于 存储 收入 的 相关 信息 。 其 结构 如 图 3.2 所 示 。 
表 3.2 tb_income 表 


字段 名 称 | 汪汪 此 说 有明 
i 自动 编号 id 


varchar rs 


varchar 一 
wah | 5 | | 


3，tb_jour (日 记 信息 表 ) 
日 记 信息 表 主 要 用 于 存储 日 记 的 相关 信息 。 其 结构 如 图 3.3 所 示 。 


表 3.3 tb_jour 表 
| 0 


收入 类 别 
收入 年 份 
收入 月 份 


自动 编号 id 


wzzt varchar 文章 主题 

rjfl varchar 日 记分 类 

wznr text 文章 内 容 
varchar 心情 


datetime 


4. tb _ motif ( 事务 主题 信息 表 ) 
事务 主题 信息 表 主 要 用 于 存储 事务 主题 的 信息 。 其 结构 如 图 3.4 所 示 。 


表 3.4 tb_motif 表 


添加 日 记 时 间 


字段 名 称 | 数据 类 型 字段 大 小 | 是 否 主键 | 说 明 
这 int 10 主键 。 ”| 自动 编号 
zhut | varchar 20 | 事务 主题 
createtime datetime 事务 主题 添加 的 时 间 
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5. tb_outgo (支出 记录 表 ) 


支出 记录 表 主 要 用 于 存储 支出 记录 信息 。 其 结构 如 图 3.5 所 示 。 
表 3.5 tb_outgo 表 


说 了 明 
id 自动 编号 id 
支出 描述 


支出 金额 
支出 时 间 | 
8 类 别 
H 年 份 | 
1 月份 | 


6. tb reg (用 户 信息 表 ) 
用 户 信息 表 主 要 用 于 存储 用 户 的 基本 信息 。 其 结构 如 图 3.6 所 示 。 


表 3.6 tb_reg 表 

字段 名 称 数据 类 型 | 字段 大 小 | 是 否 主键 说 有明 
id int | 10 | 主键 自动 编号 id 
User varchar 用 户 名 
password varchar | 80 | 用 户 密码 

rpass varchar | 80 | 确认 密码 

Zsuser varchar 真实 名 称 
SeX Varchar 性 别 
mbwt varchar 密 保 问 题 
mmda varchar 密 保 答案 


3.2.3 连接 数据 库 


由 于 网 络 日 记 的 大 部 分 页 面 都 需要 建立 与 数据 库 的 连接 ， 如 果 每 页 都 编写 相同 的 数据 
库 连接 代码 ， 会 导致 代码 见 余 ， 同 时 也 不 利于 对 程序 的 后 期 更 新 和 维护 。 所 以 可 以 考虑 将 | 
用 于 与 数据 库 进行 连接 的 代码 放 入 一 个 单独 的 文件 conn.php 中 , 以 后 在 需要 与 数据 库 进行 | 
连接 的 页 面 中 , 用 PHP 提供 的 页 面包 含 语句 包含 该 文件 即 可 。 这 样 不 仅 可 以 提高 程序 的 代 | 
码 重用 率 ， 而 且 可 以 为 日 后 程序 的 维护 带 来 很 大 方便 。 例 如 ， 当 更 改 数据 库 的 用 户 名 或 登 | 
录 密 码 时 , 上 只 需 对 conn.php 文件 进行 更 改 。 本 项 目 将 与 数据 库 进 行 连接 的 代码 封装 到 conn | 
文件 夹 的 conn.php 文件 中 ， 其 代码 如 下 : | 
0 <Iphp | 
02 $conn=mysql_connect("localhost","root","111") or die ("connect mysql false"); 
// 连 接 数 据 库 服 务 器 | 
03 mysql select db("db_diary",$conn)or die ("connect database false"); /连接 指定 的 数据 库 

04 mysql_query("set names gb2312"); 


/对 数据 库 中 编码 格式 进行 转换 ， 避 免 出 现 中 文 乱码 的 问题 | 
05 > | 


*。67 。 
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3.3 用户 模块 设计 


全 ”3.3.1 用 户 模块 概述 
用 户 要 对 网 络 日 记 进 行 操作 ， 首 先 应 该 进行 注册 ， 注 册 成 功 后 ， 可 以 有 效 地 对 用 户 信 
| 息 进 行 采集 ， 并 将 合法 的 用 户 信息 保存 到 指定 的 数据 表 中 ， 方 便 以 后 用 户 忘记 密码 时 通过 
注册 时 提交 的 密 保 问 题 与 密 保 答案 来 重 轩 密码。 用 户 注册 模块 的 运行 结果 如 图 3.8 所 示 。 


用 户 注 册 


梦幻 的 世界 欢迎 你 ! 


用 户 昵称 : 。 小米 
ET 
重 夏 密码 :e000000 
真实 姓名 : 。 李 米 
性 别 : 女 - 
密 保 问题 : 今天 的 天 气 好 吗 ? 
密 保 答案 : ”好 


EE 


图 3.8 ”用户 注册 模块 的 运行 结果 


用 户 注册 成 功 后 将 跳 转 到 登录 页 面 ， 在 登录 页 面 输入 已 注册 的 用 户 名 和 密码 方 可 登 
录 。 用 户 登录 模块 的 运行 结果 如 图 3.9 所 示 。 


Cr 

[ayo] Sy 
| 用 户 名 : 本 采 注册 账号 ? 

| 密 码 : eeeeeeee| 忘记 宏 码 ? 

| 天 EE 到 

| 吉林 省 明日 科技 有 限 公司 


| 图 3.9 用 户 登 录 模块 的 运行 结果 

| 3.3.2 ”注册 模块 实现 过 程 

| 在 注册 模块 中 ， 必 不 可 少 的 就 是 要 对 用 户 输入 的 信息 进行 判断 。 首 先 判 断 用 户 填 写 的 
| 注册 信息 中 哪些 是 必须 填写 的 ， 哪 些 可 以 不 填写 ， 然 后 进一步 判断 输入 的 信息 是 否 合理 、 
| 合法 。 例如， 判断 密码 的 长 度 不 能 少 于 6 位 。 对 表单 中 提交 数据 进行 判断 最 常用 的 办 法 就 
| 是 使 用 JavaScript 脚本 。 下 面 讲解 在 本 模块 中 如 何 通 过 JavaScript 实现 表单 提交 数据 验证 。 
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操作 原理 是 : 在 form 表单 中 调用 onsubmit 事件 ， 通 过 该 事件 调用 指定 的 JavaScript | 
脚本 ， 执 行 hkinputO 自 定义 函数 ， 实 现 对 表单 中 提交 数据 的 验证 。 在 JavaScript 脚本 中 ， | 
实现 对 表单 中 提交 数据 进行 判断 ， 判 断 输 入 的 内 容 是 否 为 空 、 内 容 的 格式 是 否 正确 ， 如 果 | 


正确 ， 则 继续 执行 ， 否 则 ， 将 弹出 提示 对 话 框 ， 并 将 鼠标 的 焦点 指定 到 出 错 的 位 置 。 具 体 
的 JavaScript 脚本 代码 如 下 : 
代码 位 置 : 配套 资 源 \mr\03\reg.php 
01 <script language="javascript"> | 
02 function chkinput(form){ // 定 义 一 个 函数 | 
03 if(form.usernc.value—""){ // 判 断 usernc 文本 框 中 的 值 是 否 为 空 | 
04 alert(" 请 输入 用 户 昵 称 ! 7; /如 果 为 空 则 输出 “请 输入 用 户 昵 称 !” ;| 
05 form usermnc .focus0; /返回 到 userne 文本 框 | 
06 return(false); | 
07 } | 
08 if(form.userpwd.value—""){ 1/ 判断 userpwd 文本 框 中 的 值 是 否 为 室 。 
09 alert(" 请 输入 注册 密码 !"); /如 果 为 空 则 输出 “请 输入 注册 密码 !” | 
10 form.userpwd .focus(); // 返 回 到 userpwd 文本 框 | 
11 Tetum(false); | 
12 } | 
13 if(form.userpwdl1.value—""){ // 判 断 userpwd1 文本 框 中 的 值 是 否 为 空 | 
14 alert(" 请 输入 重复 密码 ! 7; /如 果 为 空 则 输出 “请 输入 重复 密码 !” | 
15 form userpwdl .focus(); /返回 到 userpwdl 文本 框 | 
16 return(false); | 
17 | 
18 if(form.userpwd.value!=form.userpwd1.value){ /和 判断 两 次 提交 密码 是 否 相同 ， 
19 alert(" 密 码 与 确认 密码 不 同 ! "0); /如 果 不 同 则 输出 “密码 与 确认 密码 不 同 !” | 
20 form_userpwd.focus0; // 返 回 到 userpwd 文本 框 | 
2 return(false); | 
} | 
23 if(form.userpwd.value.length<6){ // 判 断 提 交 的 密码 长 度 是 否 大 于 6 位 | 
24 alert(" 密 码 长 度 应 大 于 6 位 !"); /如 果 不 大 于 6 位 则 给 出 提示 | 
25 form.userpwd focus(): // 返 回 到 userpwd 文本 框 | 
26 Teturn(false):; | 
27 } | 
28 if(form.truename.value—""){ // 判 断 tmename 文本 框 中 的 值 是 否 为 空 | 
29 alert(" 请 输入 真实 姓名 ! 7; // 如 果 为 空 则 输出 “请 输入 真实 姓名 !” | 
30 form.truename focus0: // 返 回 到 truename 文本 框 | 
31 return(false); | 
32 } | 
33 if(form.sex.value—""){ // 判 断 sex 文本 框 中 的 值 是 否 为 空 | 
34 alert(" 请 选择 性 别 ! 9; /如 果 为 空 则 输出 “请 选择 性 别 !” | 
35 form.sex.focus(): // 返 回 到 sex 文本 框 | 
36 return(false); | 
eh } | 
38 if(form.mb.value—""){ // 判 断 mb 文本 框 中 的 值 是 否 为 空 | 
39 alert(" 请 输入 密 保 问题 !"); // 如 果 为 空 则 输出 “请 输入 密 保 问 题 !” | 
40 form mb focus0): /返回 到 mb 文本 框 | 
41 return(false); | 
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CS 
| 42 六 
| 43 if(form mbwt.value—""){ // 判 断 mbwt 文本 框 中 的 值 是 否 为 空 
| 44 alert(" 请 输入 密 保 答案 ! "); /如 果 为 空 则 输出 “请 输入 密 保 答 案 !” 
| 45 form mbwt focus0: /返回 到 mbwt 文本 框 
| 46 return(false); 
| 47 } 
50 </script> 


| 表单 中 正确 注册 信息 将 被 提交 到 数据 处 理 页 savereg.php 中 , 在 该 页 面 中 首先 连接 数据 
| 库 ， 然 后 获取 到 表单 中 提交 的 数据 ， 最 后 对 “注册 ”按钮 进行 判断 ， 如 果 单 击 “ 注 册 ” 按 
钮 ， 则 将 数据 保存 到 对 应 的 数据 表 中 ; 相反 ， 则 给 出 提示 。 程 序 代码 如 下 所 示 : 

代码 位 置 ， 配 套 资源 \mr\03\savereg.php 


| 48 return(true); 
NEC 的 


16 ”echo"<script language=javascript>alert( 对 不 起 ， 注 册 失 败 ):historybackO;<Ascripf>"V 如 果 添 加 操 
作 失败 ， 则 给 出 提示 


| 01 ”<?php 
| 02 session start: /初始 化 session 变量 
| 03 include once("conn/conn.php"); // 包 含 数据 库 文件 
| 04 $user=trim($_POST['userne']): /去 除 表单 提交 用 户 名 的 空格 
| 05 Spwd=md5($_POST['userpwd']); // 对 表单 提交 的 密码 进行 加 密 
| 06 $qrpass=md5($_POST['userpwd1"]); 
| 07 S$zcms=trim($_POST['truename']); 
| 08 $sex=$_ POST['sex']; 
| 09 $mb=trim($_POST['mb"]); 
| 10 $mbda=trim($_POST['mbda']): 
| 11 iflisset($_ POST['submit]) ||$_POST['submit]=" 注 册 "){ // 判 断 注册 按钮 
| 12 if(mysql_query("insert into tb_reg(user,password,qrpass,zsuser,sex,mbwt,mmda) 
| 13 values('$user','$pwd','$qrpass','$zcms','$sex','$mb','$mbda')",$conn)){ /将 表单 中 提交 的 
| 数据 存储 到 数据 表 中 
| 14 echo"<script>alert(' 注 册 成 功 !"):window.location.href='enter.php';</script>"; /WW/ 注 册 
| 成 功 后 ， 将 跳 转 到 登录 页 面 
| 15 jelse{ 
| 17 } 

| 18 } 

| 1 


”3.3.3 ”登录 模块 实现 过 程 


| “登录 模块 的 实现 过 程 如 下 。 
(1) 建立 用 户 登录 表单 ， 提 交 用 户 登录 的 用 户 名 和 密码 。 登 录 页 面 的 关键 代码 如 下 : 
代码 位 置 ， 配 套 资源 \mr\03\enter.php 


01 <form id="form" name="form" method="post" action="saveenterphp”onSubmit="return 
chkinputlogin(this)"> 

02 <td width="254" valign="middle"><p align="center"> 用 户 名 : 

03 <input name="username" type="text" id="user" size="15" /> 
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迄 方 | 
04 <p align="center"> 密 码 : | 
05 <input name="pass" type="password" id="pass" size="15" /> | 
06 <a href="codeback.php"> 忘 记 密 码 ? </a></p> 
07 <p align="center"> 
08 <input type="submit" name="Submit" value=" 登 录 " /> 
09 &nbsp:&nbsp:&nbsp:<input type="submit" name="Submit2" value=" 重 置 " /> 
10 </td> 
11 </form> 


(2) 通过 JavaSeript 脚本 中 的 chkinputlogin0 方 法 验证 用 户 登录 表单 内 容 是 否 为 空 。 | 
其 主要 代码 如 下 : 
代码 位 置 : 配套 资源 \mr\03\enter.php | 


01 <script language="javascript"> 


02 function chkinputlogin(form){ /定义 函数 

03 if(form.username.value—""){ /判断 usemame 文本 框 内 容 是 否 为 空 
04 alert(" 请 输入 用 户 昵称 !"); // 为 空 则 给 出 提示 
05 form.user.focus(); 

06 return(false); 

07 } 

08 if(form.password.value—""){ 

09 alert(" 请 输入 登录 密码 !"); 

10 form.password.focus(O:; 

11 return(false); 

12 3 

13 return(true); 

14 


15 </script> 
(3) 用 户 添加 完 登录 信息 后 ， 单 击 “ 登 录 ” 按 钮 ， 登 录 信息 将 被 提交 到 用 户 登 录 信 
息 处 理 页 saveenterphp 中 。 在 登录 处 理 页 中 ， 验 证 用 户 提 交 的 用 户 名 和 密码 是 否 存在 于 数 
据 库 中 ， 存 在 则 成 功 登录 ， 并 为 成 功 登录 用 户 注册 新 的 session 变量 ， 反之， 登录 失败 给 
出 提示 。 其 主要 代码 如 下 : 
代码 位 置 ， 配 套 资源 \mr\03\saveenter.php 


01 <?php 

02 session start(): // 初 始 session 变量 

03 include("conn/conn.php"): // 包 含 数据 库 文件 | 
04 ifisset($_ POST['Submit]) && $ POST['Submit]==" 登 录 ") { ”// 判 断 “ 登 录 ” 按 钮 | 
05 $check="select user from tb reg where user=".$ POST['usermame']."and password= | 


m$_POST['pass]."™": | 
06 /检测 提交 的 数据 是 否 存在 于 数据 库 之 中 | 


07 $result=mysql_query($check,$conn); | 
08 $info=mysql_ num rows($result); ! 
09 $_SESSION['user']=$_POST['usemame']: | 
10 $_SESSION['password']=$_POST['pass']: | 
11 echo "<script>alert(' 登 录 成 功 ); window.location.href='index.php';</script>"; | 
12 }else{ | 
13 echo "<script language=javaseript>alert( 登录 失败 ， 密 码 或 者 是 用 户 名 不 正确 六 | 
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者 


history.backO;</script>"; 
14 } 
号 > 


| 3.3.4 密码 找 回 实现 过 程 


如 果 用 户 态 记 了 登录 密码 ， 可 以 通过 找 回 密码 功能 实现 密码 重 置 ， 从 而 采用 新 密码 登 
录 。 密 码 找 回 模块 的 运行 效果 如 图 3.10 和 图 3.11 所 示 。 


| 密码 找 加 新 密码 设置 

| 用 户 昵 称 : 。 下 采 填写 新 密码 : 66660008 

| 密 保 问题 : ”今天 天 气 好 吗 ? 确认 新 密码 : eeseeees| 

| 密 保管 案 : ”好 

| EC 到 
图 3.10 密码 找 回 页 面 图 3.11 密码 重 置 页 面 


密码 找 回 的 主要 步骤 如 下 : 

(1) 输入 登录 昵称 、 密 保 问题 和 密 保 答 案 。 用 户 按 要 求 输入 相关 信息 后 ， 单 击 “ 提 
交 ” 按 钮 , 后 台 代 码 将 判断 用 户 登录 昵称 是 否 存在 以 及 密 保 问 题 与 密 保 答案 输入 是 否 正 确 。 
如 果 正 确 ， 则 给 出 提示 并 进入 重 置 密码 页 面 ; 反之 ， 给 出 提示 ， 并 跳 转 到 注册 页 面 ， 其 主 
要 代码 如 下 : 

代码 位 置 ， 配套 资 源 \mr\03savecodeback.php 


01 <?php 
02 session start(): // 初 始 化 session 变量 
03 include("conn/conn.php"):; // 连 接 数 据 库 
04 iflisset($ POST[submit]) && $ POST[submit] 一 "提交 ") { /对 “提交 ”按钮 进行 判断 
05 if($_POST['userne']!="" ){ 1/ 判断 用 户 昵 称 是 否 为 空 
06 $checkl="select user from tb_reg where user="".$_POST['userne']."™"; 
| /在 数据 库 查 询 提交 的 用 户 昵 称 
| 07 $resultl=mysql query($check1.$conn): 
! 08 $row=mysql num _ rows($resultl); 
| 09 if($row<D){ /如 果 数 据 库 中 没有 提交 的 用 户 昵 称 则 给 出 提示 
| 10 echo "<script language='javascript>alert( 用 户 名 不 存在 ); historyback0; 
| </script>"; 
| 11 } 
| 12 if($_POST['mb"]!="" ){ 
| 13 $check2="select mbwt from tb _reg where mbwt=".$ POST[mb'].""; 
| 14 $result2=mysql_query($check2,$conn):; 
| 15 Srow2=mysql_num rows($result2): 
| 16 ifSrow2<1){ 
| 17 echo "<script language='javascript>alert( 密 保 问题 不 存在 ); history.back0; 
| </script>"; 
| 18 } 


Sp 
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19 这 $_POST[mbda]!="){ 

20 S$check3="select mmda from tb reg where mmda=".$ POST[mbda]."": 

21 Sresult3=mysql_query($check3,$conn); 

2 $row3=mysql num rows($result3); 

23 if($row3<1){ | 

24 echo "<script language=javascript>alert(' 密 保 答 案 不 正确 ); historybackO; | 
</script>" | 

25 }else{ 


26 ”echo"<script>alert( 重 新 修改 密码 ');window.location.href='codeback a.php?use=".$_POST 
[userne'].";</script>"; 


(2) 用 户 成 功 输入 用 户 昵 称 、 密 保 问 题 和 密 保 答案 后 进入 到 新 密码 设置 页 面 。 在 该 
页 面 中 用 户 可 以 设置 新 的 密码 并 对 新 密码 进行 确认 ， 然 后 单 击 “提交 ”按钮 ， 则 将 表单 内 
容 提交 到 savacodeback_a.php 页 面 实现 密码 更 改 操作 ， 其 代码 如 下 : 
代码 位 置 ， 配 套 资源 \mr\03\savacodeback_a.php 

01 <?php 

02 session_start(); 

03 include("conn/conn.php"):; // 包 含 数据 库 文件 

04 iflisset($ POST[submit]) && $ POST['submit]==" 提 交 ") { 


05 if($ POST['user]!="" ){ // 判 断 用 户 昵称 是 否 为 空 
06 $sql="update tb_reg set password=".md5($ POST['passx'])." where user=".$_ POST[user]."'; 
// 更 新 密码 

07 $result=mysql_query($sql,$conn); 

08 if($resul) { 

09 echo "<script language='javascript>alert( 密码 修改 成 功 ) window.location.hre 仁 
‘enter.php';</script>"; 

10 jelse{ 

11 echo "<script language='javascript>alert( 密 码 修改 失败 ); history.back(; 
</script>"; 

12 } 

13 } 

14 } 

15 > 


3.4 首页 设计 
3.4.1 首页 概述 
本 系统 的 首页 页 面 设计 比较 简单 ， 主 要 包括 以 下 4 部 分 内 容 。 
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回 ”页 由 :显示 网 络 日 记 的 名 称 。 

回 “ 左 侧 导航 栏 , 包括 “网 页 冰 钟 ”、 
和 “退出 ”导航 。 

回 “ 主 显示 区 : 包括 每 天 的 小 贴 士 、 最 新 日 记 的 列表 。 

加 ”页 尾 : 主要 包括 版 权 信 息 。 


“理财 助手 ”、“ 我 的 日 记 ”、 


“管理 日 记 本 ” 


本 项 目 首页 的 运行 效果 如 图 3.12 所 示 。 


1 全 文 | 
| as EE 闪 宙 3 间 ， 你 网 有 几 个 人 二 让 :图 
闻 : aott-otas termr 分 类 : 人 傅 
人 1 家 祯 坟 是 时 上 县 未 ， 看 到 一 折 阳光 信 好 东 到 以 边 。 可 以 不 同 多 于 起 床 ， 里 听 攻 多加 在 


: 者 顿 精 公 的 腹 备 ， 仿 劳 - 下 自己 
BMP 


星期 


文章 主题 : 走 进 你 生病 中 的 三 个 人 
发 表 时 间 : 2011-04-26 15-00-00 


周 院 轿 屏 手 科 和 93 化 球 ， 不 一 会 儿 簿 基于 的 香 匀 沐 玫 了 贡 个 房 司 。 
长 齐 走 在 任 灯 初 上 的 傅 册 ， 经 过 一 字 兰 像 店 时 正好 啊 翅 一 痊 六 过 的 


区 阐 儿 次 是 到 新 白色 89 媳 
| 亲 访 全 文 | 


共有 留 裔 3 条 每 页 嘲 示 2 条 第 1 页 / 共 2 


着 页 上 一 页 下 一 页 尾 页 


页 尾 版 权 说 明 


Ne 0431-64975301 64979962 禾 颠 .9431-94979961 
wv wingriseft coe 圳 困 央 明日 科技 有 限 公司 


| 3.4.2 通过 


图 3.12 网 络 日 记 首页 
switch 和 include 语句 设计 框架 


网 络 日 记 首页 设计 主要 应 用 switch 和 include 包含 语句 , 其 实现 的 原理 是 : 应 用 switch 
| 语句 ， 根 据 超 链接 中 传递 的 变量 值 进 行 判断 ， 根 据 不 同 的 变量 值 应 用 include 语 


名 调用 不 


| 同 的 子 文 件 。 为 了 更 好 地 理解 这 个 技术 ， 先 来 了 解 一 下 switch 语句 。 该 语句 的 格式 如 下 : 


switch(expr) { 

case exprl: 
statementl: 

break: 

Case expr2: 
statement2; 

break; 

default: 


statementN: 


//expr 为 变量 名 称 

/lcase 后 的 exprl 为 变量 的 值 

//statement 为 符合 该 条 件 时 要 执行 的 部 分 
/应 用 break 来 跳 离 循环 体 


。74 。 


第 号 章 梦幻 网 络 日 记 (Jpacfe+PHP+ MySQL 实现 ) 8 


break: 

} | 

其 中 ,参数 expr 是 表达 式 的 值 ， 即 switch 语句 的 条 件 变量 的 名 称 ; 参数 exprl 放置 于 | 
case 语句 之 后 ， 是 要 与 条 件 变 量 expr 进行 匹配 的 值 中 的 一 个 statementl 是 参数 exprl 的 | 
值 与 条 件 变量 expr 的 值 相 匹配 时 执行 的 代码 ，break 语句 实现 终止 语句 的 执行 ， 即 语句 在 
执行 过 程 中 ， 遇 到 break 就 停止 执行 ， 跳 出 循环 体 ; default 是 case 的 一 个 特例 ， 匹 配 任何 
其 他 case 都 不 匹配 的 情况 ， 并 且 是 最 后 一 条 case 语句 。 | 
通过 switch 和 include 语句 来 实现 首页 的 设计 是 一 个 很 好 的 方法 ,不 但 实现 过 程 简单 ，| 

而 且 操 作 非 常 灵 活 。 网 络 日 记 首 页 设计 的 关键 代码 如 下 : | 
代码 位 置 : 配套 资源 \mr\03\index.php | 


01 <?php | 
02 ifisset(g_GET[tink]){ // 浏 断 超 链 接 传递 的 值 是 否 存在 | 
03 Slink=$_GET['"ink’]; // 将 超 链 接 传 递 的 值 赋 给 指定 变量 | 
04 yelse{ | 
05 S$link=" 首 页 "; // 如 果 超 链接 传递 的 值 不 存在 ， 为 变量 赋 空 值 | 
06 } | 
07 switch($link){ // 以 超 链 接 变量 值 为 条 件 | 
08 case "添加 事务 主题 ": | 
09 include "motif php"; | 
10 break:; | 
11 case "查询 事务 主题 ": | 
2 include "querymotif.php"; | 
jl break: | 
14 case "设置 闹钟 ”: | 
15 include "clock.php"; | 
16 break: | 
17 case "添加 收入 ": | 
18 include "income.php"; | 
19 break: | 
20 case "添加 支出 " | 
2 include "outgo.php"; | 
22 break: | 
23 case "财务 管理 ": | 
24 include "cwglLphp": | 
25 break: | 
26 case "财务 查询 ": | 
include "affairsquery.php"; | 
28 break: | 
29 case "财务 统计 ": | 
30 include "affairsstat.php"; | 
31 break: | 
32 case "添加 日 记 ": | 
33 include "appenddiary.php"; | 
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34 break; 

35 case "查看 日 记 ": 

36 include "lookdiary.php"; 
37 break: 

38 case "查询 日 记 ": 

89 include "querydiary.php"; 
40 break; 

41 case "删除 日 记 ": 

42 include "deldiary.php"; 

43 break; 

44 case "修改 密码 ": 

45 include "amendcode.php"; 
46 break; 

47 default: 

48 include "indexs.php"; 
49 上 

50 > 


3.4.3 二 级 导航 菜单 实现 过 程 
网 站 中 的 导航 条 在 整个 网 站 中 充当 着 网 站 路 标的 角色 , 如 果 一 个 网 站 的 导航 条 层次 混乱 


或 是 分 类 不 清晰 ， 就 


对 于 一 个 网 站 万 为 


会 给 网 站 的 浏览 者 带 来 诸多 不 便 。 因 此 ， 设 计 一 个 层次 分 明 的 网 站 导航 
要 。 网 络 日 记 中 的 菜单 大 致 可 以 分 为 “网 页 疮 钟 “ 理 财 助手 “我 的 


日 记 ””“ 管 理 日 记 本 ”等 ,但 是 在 “我 的 日 记 ” 中 还 要 分 为 “添加 日 记 ”“ 查 看 日 记 ”、“ 查 
询 日 记 ” 和 “删除 日 记 ” 等 子 菜单 ， 这 就 是 所 谓 的 二 级 导航 菜单 。 将 鼠标 指针 移动 到 一 级 菜 
单 “ 我 的 日 记 ” 超 链接 上 时 ， 在 其 右 方 将 显示 与 其 对 应 的 二 级 导航 菜单 ， 如 图 3.13 所 示 。 


图 3.13 二 级 导航 菜单 


实现 二 级 导航 菜单 主要 应 用 JavaScript 的 switch 语句 确定 要 显示 的 二 级 菜单 的 内 容 ， 
switch 语句 的 语法 格式 如 下 : 
switch (expression){ 


case label : 
statement: 
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break; 


default: statement; 


} 


JavaScript 执行 switch 语句 时 ， 首 先 计算 switch 后 括号 内 表达 式 的 值 。 当 此 表达 式 的 | 
值 与 某 个 case 后 面 的 常数 表达 式 的 值 相等 时 ， 就 执行 此 case 后 的 语句 。 如 果 所 有 case 后 | 
的 常数 表达 式 的 值 都 不 等 于 此 表达 式 的 值 ， 就 执行 default 后 面 的 语句 。 

当 执 行 某 个 case 后 的 语句 时 ， 如 果 遇 到 break 语句 ， 就 结束 这 条 switch 语句 的 执行 ， 
转 去 执行 其 后 的 语句 。break 语句 也 可 以 省 略 ， 但 这 时 程序 会 一 直 执行 到 switch 语句 的 结 
束 标记 ， 即 右 大 括号 “} ”。 


注意 : | 
通常 情况 下 , 应 该 在 switch 语句 的 每 个 分 支 后 面 加 上 break, 使 JavaScript 只 执行 匹配 | 
的 分 支 。 | 


网 络 日 记 二 级 导航 菜单 实现 过 程 如 下 : | 
(1) 在 网 页 中 的 适当 位 置 添加 一 级 导航 菜单 ， 本 项 目 中 的 一 级 导航 菜单 由 一 系列 空 | 
的 超 链 接 组 成 ， 这 些 空 的 超 链接 执行 的 操作 是 调用 自 定义 的 JavaScript 函数 Fsubmenu0 显 | 
示 对 应 的 二 级 菜单 ， 在 调用 时 需要 传递 一 个 标记 ， 即 主 菜 单项 的 参数 ， 关 键 代码 如 下 : 
代码 位 置 ， 配套 资 源 \mr\03\index.php 


01 <td width="93" height="25" valign="middle" background="images/zuo_03.gif'> 

02 <a href="#" onMouseMove="Fsubmenu(' 闹 钟 )" class="shadow"> 网 页 曾 钟 </a></td> 
03 <td width="93" height="28" background="images/zuo 05.gif'> 

04 <a href="#"onmousemove="Fsubmenu(' 理 财 ")" class="shadow"> 理 财 助手 </a></td> 

05 <td width="93" height="29" background="images/zuo 06.gif'> 

06 <ahref="#" onMouseMove="Fsubmenu(' 日 记 )" class="shadow"> 我 的 日 记 </a></td> 

07 <td width="93" height="31" background="images/zuo_07.gif'> 

08 <a href="#" onMouseMove="Fsubmenu(' 管 理 )" class="shadow"> 管 理 日 记 本 </a><</td> 


(2) 在 网 页 中 显示 二 级 菜单 的 位 置 添加 一 个 名 为 submenu 的 div 层 ， 代 码 如 下 : 
<div align="center" class="shadow" id="submenu" > &nbsp;</div> 


(3) 编写 自 定义 JavaScript 函数 Fsubmenu0， 用 于 根据 鼠标 指针 移动 到 条 一 级 家 间 | 
时 ， 传 递 的 参数 值 在 页 面 中 的 相应 位 置 显示 对 应 的 二 级 菜单 ， 代 码 如 下 : 
代码 位 置 ， 配套 资源 \mr\03\index.php 

01 <script language="javascript"> 

02 function Fsubmenu(value){ 

03 switch (value){ 

04 case " 闸 钟 ": | 

05 submenu.innerHTMIL="<a hre 全 index.php?link=<?php echo urlencode(" 添 加 事务 主题 "):?>> 添 加 | 
事务 主题 </a><br> ! 
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06 <a hre 人 -index.php?link=<?php echo urlencode(" 查 询 事务 主题 ");?>> 查 询 事务 主题 
</a><br> 
07 <a href~'index.php?link<?php echo urlencode(" 设 置 闹钟 "):?>> 设 置 闹钟 </a>"; 
08 break: 
09 case "理财 ": 
10 submenu .innerHTMI 一 "<a href-index.php?link=<?php echo urlencode(" 添 加 收入 :2?>> 添 
加 收入 </a><br> 
11 <a href-'index.php?link=<?php echo urlencode(" 添 加 支出 7):2>> 添 加 支出 </a><br> 
12 <a href-'index.php?link=<?php echo urlencode(" 财 务 管理 "):?>> 财 务 管 理 </a><br> 
13 <a href-'index.php?link=<?php echo urlencode(" 财 务 查 询 ");?>> 账 务 查询 </a><br> 
14 <a href='index.php?link=<?php echo urlencode(" 财 务 统计 ");?>> 财 务 统计 </a>"; 
15 break:; 
16 case "日 记 ": 
| 17 submenu.innerHTMIL="<a href='index.php?link=<?php echo wrlencode(" 添 加 日 记 ");?>> 添 
| 加 日 记 </a><br> 
| 18 <a href='index.php?link=<?php echo urlencode(" 查 看 日 记 ");?>> 查 看 日 记 </a><br> 
19 <a href='index.php?link=<?php echo urlencode(" 查 询 日 记 ");?>> 查 询 日 记 </a><br> 
20 <a href='index.php?link=<?php echo urlencode(" 删 除 日 记 ");?>> 删 除 日 记 </a>"; 
| break: 
22 case "管理 ": 
| 23 submentLinnerHTMIL 一 "<a href='index.php?link=<?php echo urlencode(" 修 改 密码 "); 
| ?>> 修 改 密码 <Ja>"; 
24 break; 
25 
26 
2 </script> 


3.5 ”网 页 阅 钟 模块 设计 


3.5.1 网 页 闹钟 模块 概述 


用 户 登 录 后 ， 要 对 网 页 曾 钟 进行 设置 时 ， 首 先 应 添加 事务 主题 ， 单 击 导 航 栏 中 的 “网 
页 闹钟 ”/ “添加 事务 主题 ” 超 链接 ， 即 可 添加 事务 主题 。 事 务 主 题 添加 成 功 后 将 跳 转 到 网 
页 闪 钟 界面 ， 用 户 在 网 页 阔 钟 界面 直接 通过 列表 框 选 择 新 添加 的 事务 主题 即 可 。 然 后 ， 对 


出 曾 钟 输出 页 


闵 钟 提醒 的 时 间 、 提 醒 方式 以 及 提醒 铃声 进行 设置 。 事 务 主题 、 闹 钟 时 间 、 闸 钟 的 铃声 设 
置 成 功 后 ， 单 击 “ 开 启 定时 闻 钟 ”按钮 ， 表 单 中 提交 的 数据 将 被 保存 到 数据 库 中 。 当 当前 
时 间 与 设置 的 闹钟 提醒 时 间 相 同时 ， 将 弹出 “闹钟 提醒 ”对 话 框 ， 单 击 “ 确 定 ” 按 钮 ， 弹 


(control.php)， 同 时 间 钟 铃声 响起 ; 单 击 “关闭 提醒 ”按钮 ， 关 闭 阔 钟 提示 。 


闵 钟 设置 流程 如 图 3.14 所 示 。 
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添加 事务 主题 


先 
择 
闻 
钟 
锥 
和 


图 3.14 闹钟 设置 流程 图 | 
3.5.2 ”闹钟 铃声 试听 


网 页 闹钟 铃声 可 在 设置 闹钟 页 试听 ， 用 户 通过 列表 框 选择 闹钟 铃声 ， 并 单 击 “ 试 听 ” | 
按钮 ， 即 可 听 到 所 选择 的 铃声 ， 试 听 的 闹 铃 播放 时 ,“ 试 听 ” 按 钮 显示 成 “停止 ” 按 钮 ， | 
单 击 “停止 ”按钮 ， 试 听 结束 。 闹 铃 试 听 过 程 如 图 3.15 所 示 。 | 


闲 钟 设置 正在 执行 亲 名 设置 正在 执行 ! 

| 

当前 时 间 : 2011 年 4 月 26 日 13:46:04 当前 时 间 : 2011 年 4 月 26 日 13:46:50 | 
提醒 日 期 : 2011 v 年 4 月 26 日 提醒 日 期 ; 2011 > 年 4 v 月 26v 日 


提醒 时 间 : 11 > 时 33 = 分 113 = 得 


亲 钟 欠 声 : 大 要 区 到 


11 vz 时 33v 人 分 /13v 审 


| - 区] 


事务 主题 : < 开会 提醒 = 
提醒 方式 : @ 提 脸 一 次 加 每 天 提 本 日 扫 弄 一 次 加 每 天 提醒 
CE 开局 雪村 表 


图 3.15 ” 闹 铃 试听 过 程 图 
闸 铃 试听 通过 使 用 HTML 语言 中 的 bgsound 标记 实现 ， 并 且 通 过 JavaScript 动态 控制 
bgsound 标记 的 属性 ， 下 面 将 对 这 些 内 容 进行 介绍 。 
(1) 使 用 bgsound 标记 设置 闹 铃 
HTML 语言 的 bgsound 标记 的 使 用 方法 如 下 : 
<bgsound src="" loop="-1" 1d="bgsud"></bgsound> 
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参数 说 明 
回 src: 用 于 指定 曾 铃 的 地 址 。 
回 loop: 指定 是 否 循环 播放 。 
id: 为 bgsound 标记 指定 唯一 标识 。 
(2) 使 用 JavaScript 控制 曾 铃 的 播放 
在 曾 铃 的 “试听 ”按钮 中 ， 通 过 onclick 事件 调用 JavaScript 脚本 中 的 bgsd0 方 法 控制 


| 逆 铃 的 播放 与 关闭 ， 其 代码 如 下 : 


| 说明: 


<input type="button" name="subm" value= "试听 " id="subm" onclick="javascript:bgsd0" /> 
JavaScript 脚本 中 bgsd0 方 法 的 代码 如 下 : 
代码 位 置 ， 配 套 资源 \mr\03\clock.php 


01 <script language="javascript"> 
02 function bgsdO{ 


03 Var sc=document.getElementById(‘music').value: 
/使 用 getElementById() 方 法 来 访问 指定 闹钟 铃声 的 节点 
04 让 (bgsud.src 一 "){ ”// 如 果 bgsound 标记 的 src 属性 为 空 , 则 为 该 标记 指定 闹钟 铃声 
05 bgsud.src=sc; 
06 document.getElementById('subm').value=" 停 由 "; 
07 }else{ // 如 果 bgsound 标记 的 src 属性 不 为 空 ， 则 将 src 属性 赋予 空 值 
08 document.getElementById('subm').value=" 试 听 "; 
09 bgsud.sre=""; 
10 } 
11 } 
12 </script> 


用 户 应 先 把 闹 铃 铃声 的 音乐 文件 复制 到 项 目 目 录 music 文件 中 ， 并 重新 命名 成 英文 名 


， 称 ， 然 后 在 设置 阅 铃 页 将 闻 铃 添加 到 选择 亲 铃 的 列表 框 中 ， 并 把 重新 命名 的 英文 名 称 设置 
| 成 相对 应 的 列表 框 的 值 ， 代 码 如 下 所 示 。 


<select name="music" size="1" id="music"> 
<option value="musicbg mp3"> 怒 放 的 生命 <option> 
<option value="music/dh.mp3"> 传 奇 </option> 
</select> 


3.5.3 Ajax 无 刷新 控制 闹 铃 


通过 Ajax 技术 实现 网 页 曾 钟 的 无 刷新 提交 , 首先 要 创建 一 个 XMLHttpRequest 对 象 实 


| 例 ， 确 保 其 能 够 在 所 有 支持 XMLHttpRequest 的 浏览 器 中 运行 ， 将 其 代码 保存 在 一 个 名 称 
| 为 xmlHttpRequestjs 的 文件 中 ， 然 后 在 需要 应 用 Ajax 技术 的 页 面 中 ， 应 用 以 下 代码 包含 
| 该 文件 。 


<script type="text/javascript" src="js/xmlHttpRequest.js"></script> 
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xmlHttpRequestjs 文件 的 代码 如 下 : 
代码 位 置 ， 配套 资源 \mr\03\ js\xmlHttpRequest.js 


01 var xmlHttp = false: /创建 一 个 布尔 型 变量 ， 用 来 检测 是 否 为 合法 的 正 实例 
02 tyf{ /检测 是 否 使 用 的 是 下 

03 xmlHttp = new ActiveXObject("Msxml2.XMLHTTP'"); /如 果 JavaScript 的 版 本 大 于 5 
04  }catch(e){ /如 果 不 是 ， 则 使 用 老 版 本 的 ActiveX 对 象 

05 ty{ /如 果 使 用 的 是 正 浏览 器 

06 xmlHttp = new ActiveXObject("Microsoft. XMLHTTP"); 

07 } catch (e2) 他 

08 


10 if(IxmlHttp &&c typeof XMLHttpRequest != "undefined") { 


11 try{ 

12 xmlHttp = new XMLHttpRequest(); 
13 }catch(e3){ xmlHttp = false;} 

14 } 


接 下 来 编写 JavaScript 自 定义 函数 ShowTime()， 并 通过 ShowTime() 函 数 调 用 
showtime.php， 完 成 对 闹钟 设置 时 间 与 当前 时 间 的 比较 ， 如 果 当 前 时 间 与 闹钟 设置 的 时 间 
相同 ， 则 弹出 闹钟 提醒 信息 ， 并 且 调 用 control.php 文件 播放 闹钟 设 定 的 音乐 。ShowTimeO 
函数 的 代码 如 下 : 

代码 位 置 ， 配套 资源 \mr\03\ index.php 
01 <script type="text/javascript"> 
02 timer=window.setInterval("ShowTime(O)",1000): // 每 隔 一 秒 钟 调用 一 次 ShowTime0 函 数 
03 ”// 定 义 ShowTime0 函 数 以 通过 xmlHttpRequest 对 象 读 取 showtime.php 文件 中 的 数据 
04 function ShowTimeO{ 


05 xmlHttp.open("post","showtime.php", true); /以 post0 方 法 发 送 一 个 新 请 求 

06 xmlHttp.onreadystatechange = functionO{ 

07 if(xmlHttp.readyState 一 4){ /如 果 服 务 器 响应 发 出 的 请 求 ， 则 执行 以 
下 操作 

08 tet = xmlHttp.responseText: // 获 取 返 回 的 响应 信息 

09 * 六 林 术 本 本 六 本 本 不 本 站 本 将 获取 到 的 信息 赋予 指定 的 DIV 标 记 闻 让 站 李 率 村 让 让 本 率 率 束 素 素 素 / 

10 if(tet!=0){ // 判 断 如 果 当 前 返回 值 不 等 于 0 

11 alert( 闸 钟 提醒 ! 7): /弹出 闹钟 提醒 

2 window.location.href='control. php?ids='+id: // 打 开 曾 钟 显示 页 

13 } 

14 } 

15 |: 

16 xmlHttp.send(null); /发 送 请 求 

ys 下 

18 </script> 


在 showtime.php 文件 中 将 当前 时 间 与 数据 库 闹钟 设置 的 时 间 进 行 比 较 。 其 实现 的 原理 
是 : 首先 应 用 date0 函 数 获取 当前 的 时 间 , 然后 应 用 mysql_query0 函 数 查询 数据 表 tb_clock 
的 数据 ， 当 用 户 选择 的 提醒 方式 为 “提醒 一 次 ”时 ,利用 函数 substr0 把 当前 时 间 与 闹钟 设 
置 的 时 间 都 截取 到 日 ， 当 当前 时 间 与 闹钟 设置 的 时 间 相 同时 ， 闹 铃 响起 ， 当 用 户 选择 的 提 
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} 
09 化 *****#*#*** 加 果 使 用 的 是 非 正 浏览 器 , 则 创建 一 个 该 对 象 的 JavaScript 实例 *******#* */ | 
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| CD 
| 
| 醒 方式 为 “每 天 提醒 ”时 ,利用 函数 substr0 把 当前 时 间 与 闹钟 设置 的 时 间 都 截取 到 时 ， 当 
| 当前 时 间 与 闹钟 设置 的 时 间 相 同时 ， 闹 铃 响起 ， 代 码 如 下 : 

| 代码 位 置 : 配套 资源 \mr\03\ showtime.php 


01 <?php 
02 session start(); // 初 始 化 session 变量 
03 header(Content-Type: text/xml; charset=gb23127); /设置 编码 格式 
| 04 include("conn/conn.php"); // 包 含 数 据 库 文件 
| 05 $dates=date("Y-m-d H:i:s"); // 获 取 当 前 时 间 
! 06 $result=0; // 定 义 返 回 值 
| 07 $sql=mysql query("select * from tb_clock"):; // 指 定 查询 语句 
| 08 while($myrow=mysql fetch array($sqD){ // 循 环 输出 查询 结果 
| 09 这 Smyrow['control] 一 1){ /判断 如 果 值 为 1, 说 明 闻 钟 时 间 过 其 
| 10 if($myrow['tsfs]=—"1"){ // 如 果 为 提醒 一 次 
| 11 Severy=substr($dates, 8,5); 
| 12 S$control=substr($myrow['clocknow'],8,5); 
| 13 if($every—$controD){ // 判 断 当 前 时 间 与 数据 库 时 间 相 同 
| 14 $_SESSION['controls]=$myrow['id]; /将 值 赋 给 SESSION 变量 
| 15 Sresult=$myrow['music']:; // 将 所 使 用 的 铃声 赋 给 返回 值 
| 16 }else{ 
| 17 $result="0’; 
| 18 } 
| 19 jelse{ 
| 20 S$every=substr($dates,11,2); 
| 21 $control=substr($myrow['clocknow'],11,2): 
| 22 if($every—$contro){ 
| 23 $_SESSION['controls']=$myrow['id']: 
| 24 $result=$myrow['music']; 
| 25 jelsef 
| 26 Sresult=0; 
| 27 } 
| 28 } 
| 29 jelsef{ 
| 30 Sresult-0; 
| 31 } 
| 300 
| 33 echo $result; // 输 出 返回 值 
| 34 > 


最 后 在 controlLphp 页 面 中 显示 闹钟 的 相关 信息 ， 代 码 如 下 : 
代码 位 置 ， 配套 资源 \mr\03\ control.php 


| 01 <?php 
| 02 include("conn/conn.php"): // 连 接 数 据 库 文件 
| 03 ”// 通 过 获取 隐藏 域 传递 的 id 的 值 ， 查 询 闹 钟 相关 信息 
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04 $myrow=mysql query("select * from tb_clock where id=".$_GET['ids']."",$conn); 


// 执 行 查询 语句 
05 $result=mysql fetch array($myrow); /获取 查询 结果 
06 > 
07 <bgsound src="<?php echo $result['music']:?>" loop="1" id="bgsud"></bgsound> 
08 <?php 
09 iflisset($ POST[id]){ // 对 查询 的 id 进行 判断 
10 Sresult=mysql_query("update tb_clock set control=’0' where id=".$ POST['id]."",$conn); | 
11 if($resulO) { | 
12 echo "<script>alert( 提 醒 关闭 ):windowlocation href='index.php':</script>"; | 
13 }else{ | 
14 echo "false"; | 
1) 1 
16 } 
17 ?> 


18 <form id="form1" name="forml1" method="post" action="control.php"> 
19 <tableid=" 01"width="255" height="221" border="0" cellpadding="0" cellspacing="0"> 


20 <tr> | 
2 <td colspan="3"><img src="images/n_01.gif" width="255" height="104" alt=""></td> | 
到 </tr> | 
23 <tr> | 
24 <td width="255" height="76" colspan="3" background="images/n 02.gif'"><?php echo | 
$result['tsnr']:?>&nbsp: | 
25 </td> | 
26 </tr> | 
27 <tr> | 
28 <td> | 
29 <img src="images/n_03.gif"' width="102" height="41" alt=""></td> | 
30 <td><input type="image" name="imageField" src= images 04.gif" onclick="" /></td> | 
31 <td><img strc="images/n 05.gif" width="87" height="41" alt=""></td> | 
2 </t> | 
33 </table> | 
34 <input type="hidden" name="id" id="id" value="<?php echo $_GET['ids']:?>" /> | 
35 </form> | 


3.5.4 网 页 闹钟 设 定 的 实现 过 程 


网 页 曾 钟 的 设 定 主要 包括 事务 主题 的 添加 、 日 期 时 间 的 设 定 、 闹 铃 的 选择 、 提 醒 方式 | 
的 选择 等 。 闹 钟 设置 成 功 后 ， 数 据 将 被 保存 到 数据 库 中 ， 当 当前 时 间 与 闹钟 设置 的 时 间 相 
同时 ， 弹 出 冰 钟 提醒 对 话 框 ， 单 击 “ 确 定 ”按钮 则 显示 闹钟 事务 主题 提醒 页 ， 单 击 “ 关 闭 
提醒 ”按钮 即 关闭 闹 铃 ， 同 时 闸 钟 提醒 也 关闭 。 网 页 闹钟 设 定 的 流程 如 图 3.16 所 示 。 | 
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图 3.16 网 页 闹钟 设 定 的 流程 


网 页 亲 钟 设 定 的 实现 过 程 如 下 : 

(1) 单 击 “ 网 页 闹钟 ”/“ 添 加 事务 主题 ” 超 链接 ， 进 入 到 添加 事务 主题 页 面 ， 事 务 
主题 成 功 添加 后 ， 将 通过 $_POST( 方 法 提交 到 事务 主题 处 理 页 ， 在 处 理 页 中 将 对 提交 的 事 
务 主题 进行 查询 , 如 果 提交 的 事务 主题 在 数据 库 中 存在 , 则 给 出 提示 并 跳 转 到 设置 闹钟 页 ， 
用 户 可 以 在 设置 闹钟 页 直接 选择 已 经 存在 的 事务 主题 ; 反之 ， 则 添加 成 功 。 事 务 主题 处 理 
页 的 代码 如 下 所 示 : 

代码 位 置 ， 配套 资源 \mr\03\chkmotif.php 


01 <?php 

02 session start: // 初 始 化 seesion 变量 

03 include once("conn/conn.php"); // 包 含 数 据 库 文件 

04 S$zhu=trim($ POST["zt"]); /去 除 主题 前 面 的 空格 

05 $sql=mysql_query("select zhut from tb_motif where zhut=".$zhu."",$conn); 

// 查 询 提 交 的 事务 主题 是 否 存 在 

06 $info=mysql fetch array($sql); // 获 取 查 询 结果 

07 这 $info){ /判断 事务 是 否 已 经 添加 

08 echo"<script>alert(' 添 加 失败 ， 事 务 主题 已 经 存在 !):history.backO:</script>"; 

09 exit; 

10 } 

11 if(strlen($zhu)>12){ // 通 过 strlen0 函 数 统计 提交 的 事务 主题 字数 

1 echo"<script>alert(' 主 题字 数 不 能 超过 6 汉字 ');history.backQ0;</script>"; 

13 exit; 

14 : 

15 Screatetime=date("Y-m-d H:i:s"); // 获 取 当 前 时 间 

16 这 mysql_query("insert into tb_motif(zhut,createtime) values('$zhu','$createtime’)",$conn)){ 

17 echo"<script>alert( 事 务 主 题 添加 成 功 !):windowlocation href=index.php?link=".urlencode 
(设置 闹钟 ).":</script>"; 

18 Jelse{ 

19 echo"<script>alert( 事 务 主题 添加 失败 1"):history.backO;</script>"; 

20 exit; 


.84. 
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新 和 
2 | 
(2) 事务 主题 添加 成 功 后 ， 跳 转 到 设置 闹钟 页 ， 在 该 页 面 中 设置 闹钟 的 提醒 日 期 和 
时 间 ， 选 择 闹钟 铃声 以 及 提醒 方式 等 。 闹 钟 信息 成 功 设置 后 ， 通 过 $ POST( 方 法 将 数据 提 | 
交 到 闹钟 处 理 页 。 闸 钟 信息 处 理 页 的 代码 如 下 : | 


代码 位 置 : 配套 资源 \mr\03\setclock.php 
01 。 <?zphp | 
02 include once("conn/conn.php"); // 包 含 数据 库 连接 文件 
03 iflisset($ POST['Submit2'"])){ // 判 断 提交 值 是 否 存在 
04 $ye=$_ POST[year]; /获取 提交 的 数据 
05 $mon=$_ POST[month']; 
06 $da=$_POST['day']; 
07 $ho=$_ POST[hour]; 
08 $min=$ POST[minute']: 
09 $sec=$_ POST['second']; 
10 $txfs=$ POST['fs"]; 
11 $yy=$_POST['music']; 
12 S$txzt=$_POST['zht']; 
13 Snowes=$ye."-". $mon."-".$da." ".$ho.":".$min.":".$sec; // 定 义 时 间 字 符 串 
14 $nowe=date("Y-m-d H:i:s",strtotime($nowes)); | 
15 $sql="insert into tb clock (clocknowmnusictsnrtsfs,controD values (".$nowe.",".$yy.", | 
er | 
16 这 mysql_ query($sqD){ /执行 添加 语句 
17 echo"<script>alert(' 曾 钟 设置 成 功 !"):;history.back(:;</script>"; 
18 yelse{ 
19 echo"<script>alert(' 阐 钟 设置 失败 !1"):history.back(;</script>"; 
20 } 
21 } 
2 > 


(3) 当当 前 时 间 与 闹钟 设置 的 时 间 相 同时 将 弹出 闹钟 提醒 对 话 框 ， 单 击 对 话 框 中 的 
“查看 ”按钮 ， 将 弹出 闹钟 事务 主题 显示 页 面 同时 间 铃 响起 ; 单 击 “ 关 闭 提 示 ” 按 钮 将 关 | 
闭 闹 铃 提醒 。 其 实现 的 过 程 请 参见 3.5.3 节 ， 这 里 不 再 袭 述 。 | 


3.6 理财 助手 模块 设计 


3.6.1 理财 助手 模块 设计 概述 


理财 助手 模块 主要 由 5 个 子 模块 组 成 ， 包 括 添加 收入 、 添 加 支出 、 财 务 管理 、 财 务 查 | 
询 和 财务 统计 。 添 加 收入 (支出) 模块 主要 用 于 用 户 添加 收入 〈 支 出 ) 描述 、 人 金额 以 及 时 | 
间 ; 财务 管理 模块 主要 用 于 用 户 对 添加 的 收入 和 支出 进行 修改 和 删除 :财务 查询 模块 主要 | 
用 于 对 一 段 时 间 内 的 收入 总 额 、 消 费 总 额 以 及 余额 进行 查询 ， 财 务 统计 模块 主要 用 于 统计 | 
某 一 年 的 消费 情况 。 理 财 助 手 的 设计 流程 如 图 3.17 所 示 。 | 


SB L_ 


| 图 3.17 理财 助手 的 设计 流程 图 

”3.6.2 验证 日 期 格式 是 否 正确 

| 在 添加 收入 和 添加 支出 模块 中 ， 都 需要 手动 输入 收入 金额 和 添加 时 间 。 要 确保 用 户 输 
| 入 日 期 的 有 效 性 , 首先 应 验证 用 户 输入 的 日 期 是 否 合法 , 以 此 来 有 效 提高 程序 的 执行 速度 。 
| 在 “添加 收入 ”页 面 中 的 “收入 时 间 ” 文 本 框 中 输入 2007-02-29， 单 击 “ 添 加 ”按钮 后 ， 
| 将 弹出 如 图 3.18 所 示 的 对 话 框 。 


您 给 入 收入 日 期 不 正确 (如 : 2007-12-01 ) 
请 注意 同年 ! 


图 3.18 弹出 日 期 不 合法 的 提示 


应 用 JavaScript 编写 验证 输入 的 日 期 格式 是 否 正确 的 代码 时 ， 需 要 注意 以 下 几 点 。 
| (1) 首先 需要 从 输入 的 字符 串 中 提取 出 年 份 、 月 份 和 日 ， 并 判断 输入 的 年 份 、 月 份 
| 和 日 是 否 是 大 于 0 的 数字 ， 然 后 将 月 份 和 日 中 小 于 10 的 数字 格式 化 为 长 度 为 2 的 字符 串 
(在 其 前 面 填充 “0”)。 
| (2) 将 提取 并 格式 化 后 的 年 份 、 月 份 和 日 重新 组 合 ， 使 其 组 合成 为 YYYY-MM-DD 
| 格式 的 字符 串 ， 并 判断 新 组 合 的 字符 串 长 度 是 否 为 10。 
(3) 判断 输入 的 年 份 是 否 为 关 年 ， 从 而 判断 2 月 份 的 天 数 。 


| 说明， 
| 半年 的 条 件 是 能 被 4 整除 ， 但 不 能 被 100 或 者 400 整除 。 


了 。86 . 


(4) 根据 1、3、5、7、8、10、12 月 份 为 31 天 ， 其 他 月 份 为 30 天 的 原则 ， 判 断 除 2 
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月 份 以 外 的 其 他 月 份 的 天 数 是 否 正确 。 
(5) 判断 月 份 是 否 大 于 12。 


其 中 还 应 用 了 正则 表达 式 来 判断 日 期 的 基本 格式 ， 正 则 表达 式 的 语法 如 下 : 
/0d{4}-)0q{2}-)0q{2))8/; 


在 本 项 目 中 ， 验 证 日 期 的 实现 过 程 如 下 : 


(1) 应 用 JavaScript 编写 验证 输入 的 日 期 格式 是 否 正确 的 函数 checkdata0, 代码 如 下 : 


代码 位 置 ， 配 套 资源 \mr\03\ js\function.js 


01 
02 


<script language="javascript"> 
1/ 判断 输入 的 日 期 是 否 正确 
function checkdata(data){ 

if (data—""){return true;} 


subYY=data.substr(0,4) 
if(isNaN(subYY) || subYY<=0){ 
return true; 
l 
// 转 换 月 份 
if(data.indexOf('-',0)!=-1){ separate="-"} 
else{ 
return true;} 
area=data.indexOf(separate,0) 
subMM=data.substr(area+1,data.indexOf(separate,areat+1)-(areat+1)) 
iflisNaN(subMMD || subMM<=0){ 
return true; 
了 
if(subMM.length<2){subMM="0"+subMM?} 
/转换 日 
area=data.lastIndexOf(separate) 
subDD=data.substr(areat+1,data.length-area-1) 
if(isNaN(subDD) || subDD<=0){ 
return true; 
} 
if(eval(subDD)<10) {subDD="0"+eval(subDD)} 
NewDate=subYY+"-"+subMM+"-"+subDD 
if({NewDate.length!=10){retum true;} 
if(NewDate.substr(4,1)!="-") {return true;} 
if({NewDate.substr(7,1)!="-"){return true;} 
var MM=NewDate.substr(5,2); 
var DD=NewDate.substr(8,2); 
f(subYY%4 一 0 && subYY%100!=0)|subYY%400 一 0){ // 判 断 是 否 为 国 年 
这 parseInt(MMD 一 2){ 
iDD>29)fretum true;} 
} 
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jelse{ 
这 parseInt(MMD 一 2){ 
1f{(DD>28) {returm true;} 
} 
B 
var mm-new Array(4,6,9,11); // 判 断 每 月 中 的 最 大 天 数 
for(i=0;i< mm.length:i++){ 
if (parselnt(MM) 一 mmfi){ 
if(parseInt(DD)>30) {returmn true;} 
Jelse{ 
if(parseInt(DD)>31) {return true;} 
} 
上 
if(parseInt(MM)>12){return true;} 


</script> 


由 于 在 其 他 的 模块 中 还 需要 添加 日 期 ,因此 将 上 面 验证 日 期 的 代码 作为 一 个 公共 文件 
存储 于 function.js， 在 需要 对 日 期 进行 验证 时 直接 调用 此 文件 即 可 。 


(2) 应 用 JavaScript 脚本 编写 一 个 checkdata10 函 数 ， 并 通过 正则 表达 式 验 证 用 户 输 
入 的 日 期 格式 是 否 正 确 ， 代 码 如 下 : 
代码 位 置 ， 配 套 资源 \mr\03\ income.php 


01 
02 
03 
04 
05 
以 2 个 数字 结尾 


<script language="javascript"> 
function checkdatal(srsj){ 


Var str=srsj; 
/在 JavaScript 中 ， 正 则 表达 式 只 能 使 用 “/” 开 头 和 结束 ， 不 能 使 用 双 引 号 
var Expression=/Cd{4}-)Cd{2}-)Qdf2)$/ /匹配 字符 串 中 的 指定 位 数 ，Qd{2})$ 表 明 


Var objExp=new RegExp(Expression); 
if(objExp.test(str)==true){ 
return true; 
}else{ 
Tetum false: 
} 


</script> 


(3) 编写 自 定义 JavaScript 函数 chkinput0， 用 于 在 提交 表单 前 判断 用 户 输入 是 否 合 


法 , 在 该 函数 中 再 调用 checkdata0 和 checkdatal0 函 数 判断 输入 的 日 期 是 否 正确 ,如果 不 正 


确 ， 则 给 予 提示 ; 否则， 提交 表单 ， 关 键 代 码 如 下 : 
代码 位 置 : 配套 资源 mrv03\income.php 


01 <script language="javascript"> 
02 function Chkinput(form){ 
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03 这 form srsj.value—""){ // 判 断 时 间 值 是 否 为 空 

04 alert(" 请 输入 收入 时 间 ! "); 

05 form.srsj.focusO; 

06 Tetum(false); 

07 } 

08 这 !checkdatal(forml.srsj-valuejllforml.srsj.valuelength!=10){ // 验 证 时 间 是 否 合 理 

09 alert(" 您 输入 的 基本 格式 不 对 !"); 

10 form!1 .srsj.focus():; 

I return(false); | 
12 } | 
13 i CheckDate(form.srsj.value)){ // 验 证 格式 是 否 正 确 | 
14 alert(" 您 输入 收入 日 期 不 正确 (如 : 2007-12-01)\n 请 注意 闽 年 ""); | 
15 form.srsj.focus(); | 
16 retum false: | 
17 } | 
18 } 

19 </script> 


3.6.3 日 期 选择 器 


日 期 型 数据 格式 有 多 种 ， 采 用 输入 方式 相对 来 说 比较 烦琐 ， 而 且 也 不 利于 日 期 格式 的 | 
统一 ， 所 以 在 财务 查询 页 面 中 采用 弹出 对 话 框 选择 时 间 来 实现 。 | 
通过 调用 window 对 象 的 showModalDialog0 方 法 弹出 一 个 窗口 ， 当 用 户 选择 日 期 后 ， | 
将 对 应 的 数值 传递 给 父 窗口 , 通过 传递 过 来 的 数值 指定 用 户 所 选择 的 日 期 。 实现 过 程 如 下 。 | 
(1) 首先 在 页 面 添 加 图 像 域 国 ， 以 便 调用 loadCalendar0 函 数 实现 窗口 的 弹出 功能 ， | 
代码 如 下 : 
<img src="images/sj.jpg" width="17" height="15" onclick="loadCalendar(form.p_datel1)" /> 


(2) 利用 JavaScript 编写 loadCalendar0 函 数 ， 实 现 日 期 选择 窗口 的 弹出 以 及 返回 用 | 

户 所 选择 日 期 对 应 的 数值 ， 代 码 如 下 : | 
代码 位 置 ， 配套 资源 \mr\03\ js\rig.js 

01 <script language="javascript"> | 

02 function loadCalendar(field){ | 

03 var rtn = window.showModalDialog("calender.php"," 请 选择 查询 日 期 ", | 

04 "dialogWidth:250px:dialogHeight:220px:;status:no;help:no:;scrolling=no;scrollbars=no"); | 


05 ifltrtn!=null) | 
06 field.value=rtn: | 
07 return; | 
0800 | 
09 </script> | 


(3) 在 弹出 窗口 中 通过 CheckDate 0 函数 返回 用 户 所 选择 日 期 对 应 的 数值 ， 代 码 如 下 : 
代码 位 置 ， 配 套 资源 \mr\03\calender.php 
01 function CheckDate(strDay) { 
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\E% 

| SI 

| 02 Var docFrm = documentcalendar: 

| 03 var choice daynum = 0; 

| 04 var current_daynum = 0; 

| 05 var day_temp; 

优 F| | 06 if (strDay (="") { 
| 07 Var strY = docFrm.yearList.value; 
08 Var strM = docFrm.monthList.value; 

| 09 Var curr y = new String(yearNow); 

| 10 var cuUT m= new String(monthNow); 

| 11 Var curr d= new String(dayNow): 

| 12 if(cur mlength 一 1]) cur m= "0"+cur m; 

| 13 if (curr dlength— 1) curr d="0"+cur d: 

| 14 current_daynum = new Number(curr y + curr m+ curr d) ; 
15 if (strM.length 一 1) sttM = "0"+strM; 
16 if (strDay.length 一 1) strDay = "0"+strDay; 
7 choice_daynum = new Number(strY + strM + strDay); 
18 parentwindowretumValue = strY+"-"+strM+"-"+strDay; /将 选择 的 日 期 传递 到 父 窗口 中 
19 parent.window.close(); 
20 } 
21 Teturn false; 
22 } 


说 明 : 
为 了 减少 代码 的 宛 余 ， 将 弹出 日 期 窗口 的 代码 存储 于 riqjs 文件 中 ， 验 证 日 期 代码 存 
储 于 calenderphp 文件 中 。 


3.6.4 无 边框 窗口 
本 项 目 中 对 财务 记录 的 修改 是 在 弹出 的 无 边框 窗口 中 进行 的 ,实现 无 边框 窗口 使 用 的 
是 JavaScript 脚本 中 的 open0 方 法 。open0 方 法 的 常用 格式 如 下 : 
window.open(url,name,features,replace); 
open() 方 法 中 的 参数 说 明 如 表 3.7 所 示 。 
| 表 3.7 open() 方 法 的 参数 说 明 


| 属 性 值 说 有明 

| ml | 在 弹出 窗口 中 要 打开 的 地 址 

| name | 要 打开 窗口 的 名 字 。 在 使 用 target 属 性 时 会 用 到 ， 可 以 为 空 

| features | 列举 的 窗口 特征 。 如 果 不 写 任何 参数 ， 那 么 默认 的 参数 多 数 情况 下 是 关闭 的 
| replace -个 boolean 值 ， 指 出 是 否 蔡 换 当前 内 容 。 该 参数 可 以 省 略 不 写 


下 面 应 用 window 对 象 的 open0 方 法 打开 一 个 指定 大 小 的 窗口 ， 代 码 如 下 : 


| <a href="#" onclick="javascript:window.open(addtype.php?checks id=<?php echo $info['id']:?>&type 
| =<?php echo $ POST['check']:?> ',","width=510,height=265"):"> 修 改 </a> 
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收入 据 述 ;| 1 月 投资 收入 《请 不 要 超过 20 个 汉字 》 


收入 全 旺 : | 1445 元 (六 加 内 到 必须 为 数字 如; 1000) 
| 
着: | 其 但 


收入 时 间 : | 2011-01- 吧 (日 期 格式 为 : 2007-12-01) 


EE 


后 @ Internet | Spt 用 


图 3.19 ”使 用 open0 方 法 弹出 窗口 
除了 上 面 介绍 的 几 个 窗口 特征 ， 表 3.8 列 出 了 其 他 几 个 常用 的 特征 参数 及 说 明 。 
表 3.8 浏览 器 窗口 的 外 观 样式 


属 性 值 说 了 明 
left 新 窗口 的 左 坐 标 
to 新 窗口 的 上 坐标 ， 配 合 left 可 以 定位 一 个 窗口 的 弹出 位 置 
Tesizable 是 否 可 以 通过 拖 搜 来 调整 新 窗口 的 大 小 ， 默 认为 no 
status 在 新 窗口 中 是 否 显示 状态 栏 ， 默 认为 no 
注意 


窗口 特征 是 用 等 号 赋值 、 过 号 分 隔 的 ， 过 号 或 等 号 前 后 不 要 加 空格 ， 因 为 在 有 些 浏览 | 
器 中 会 显示 错误 | 
3.6.5 ”添加 收入 实现 过 程 


添加 收入 功能 是 向 数据 库 中 添加 收入 的 详细 信息 ， 包 括 收入 描述 、 收 入 金额 、 收 入 时 | 
间 和 类 别 。 添 加 收入 页 面 的 运行 结果 如 图 3.20 所 示 。 | 


添加 收入 

收入 描述 : “奖金 (请 不 要 超过 20 个 汉字 ) 

收入 金额 ; 2000 元 《添加 内 容 必须 为 数字 ， 如 : 1000) 
类 别 : 奖金 > 


收入 时 间 : 12011-04-27| | 提 期 格式 为 : 2007-12-01) 
E 到 
图 3.20 添加 收入 页 面 


添加 收入 的 实现 过 程 如 下 。 | 
(1) 创建 添加 收入 的 表单 文件 income.php。 在 income.php 文件 中 创建 的 表单 元 素 如 | 
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| 表 3.9 所 示 。 
| 表 3.9 添加 收入 页 中 使 用 的 重要 表单 元 素 
| 名 称 | 元 素 类 型 重要 属性 含义 
傅 放 | | form name="forml" method="post" action= 添加 收入 的 
~ | foml form 
| "chkincome.php" 表单 
Mote srms, text input type="text" name="srms" id="srms" 收入 描述 
| seje text input name="seje" type="text" id="seje" size="10" 收入 金额 
| <select name="select" size="1" id="select"> 
| <option> 汇 款 </option> 
| <option> 奖 金 </option> 
| <option> 补 助 </option> 
| select select <option> 工 资 </option> 选择 收入 分 类 
| <option> 其 他 </option> 
| <option selected="selected"> 请 选择 
| </option> 
| </select> 
| srsj text input name="srsj" type="text" id="srsj" size="10" 收入 时 间 
i et input pe nl et value=" 添 加 " id= 提交 表单 
| "Submit" onclick="return chkinput(form1)" 


(2) 通过 JavaScript 脚本 验证 各 表单 元 素 是 否 为 空 ， 其 主要 代码 如 下 : 
代码 位 置 : 配套 资源 \mr\03\income.php 


| 01 <script language="javascript"> 
| 02 function chkinput(form){ 


03 if(form.srms.value—""){ 
04 alert(" 请 输入 收入 描述 ! "); 
05 form.srms.focus(): 
| 06 Teturn(false); 
| 07 } 
| 08 if(form.seje.value—""){ 
| 09 alert(" 请 输入 收入 金额 ! 7; 
| 10 form.seje.focus(); 
! 11 return(false); 
| 12 
| 13 if(isNaN(form.seje.value){ 
| 14 alert(" 请 输入 有 效 的 金额 !"); 
| 15 form seje focus0: 
| 16 return(false); 
| 17 } 
| 18 if(form.srsj.value—""){ 
| 19 alert(" 请 输入 收入 时 间 ! "); 
| 20 form.srsj.focus(): 
| Dl return(false); 
| 29 } 
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23 if(!checkdatal(form!].srsj.value)|lform!l .srsj.value.length!=10){ 

24 alert(" 您 输入 的 基本 格式 不 对 !");forml.srsi.focus(; 

25 return(false); 

26 D 

27 if(CheckDate(form.srsj.value){ 

28 alert(" 您 输入 收入 日 期 不 正确 (如 : 2007-12-01) \n 请 注意 闽 年 !"); 

29 form.srsj.focus(): 

30 Teturn false; 

31 } | 
到 returmn(true); | 
3 } | 
34 </script> 


(3) 通过 $_POSTO 方 法 获取 表单 中 提交 的 数据 ,在 chkincome.php 文件 中 对 表单 中 提 
交 的 数据 进行 处 理 ， 将 数据 存储 到 指定 的 数据 表 中 ， 其 关键 代码 如 下 : 
代码 位 置 ; 配套 资源 \mr\03\ chkincome.php 


01 <?php 

02 session start: // 初 始 化 session 变量 
03 include once("conn/conn.php"); // 包 含 数 据 库 连 接 文件 
04 Sms=trim($ POST['srms']); /获取 表单 提交 的 数据 


05 $je=$_POSTT['seje']; 

06 $sj=$ POST[srsi]; 

07 Syear=substr($sj,0,4); 
08 $month=substr($sj,5,6); 
09 $lb=$_ POST['select]; 


10 if(strlen(Sms)>20){ /验证 主题 的 字符 串 长 度 
11 echo"<script>alert(' 主 题字 数 不 能 超过 20 个 汉字 '):historybackO;</script>"; 
12 exit; 

13 } 


14 if(mysql_query("insert into tb_income(srms,srje,srsi,year,month,lb) values('$ms','$je','$s)','$year', 
‘$month','$lb")", $conn) { 
15 echo"<script>alert( 收 入 添加 成 功 !):history backO:</scriptf>": 


16 ee 

17 echo"<script>alert( 收 入 添加 失败 !):history backO:</script>": 

18 exit; 

50 

20 > | 
二 关键 代码 解析 | 


04 。 trim0: 删除 “收入 描述 ”文本 框 中 首尾 的 空白 或 者 其 他 字符 
07 substr0: 对 提交 收入 时 间 的 年 进行 截取 。 | 
10 ”strlenO 〇 : 获取 收入 描述 的 长 度 。 


说 明 : 
由 于 添加 支出 与 添加 收入 的 实现 过 程 相似 ， 这 里 不 再 鞭 述 。 读 者 可 以 参考 配套 资源 中 
的 源 文件 。 
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3.6.6 ”财务 管理 实现 过 程 


| 在 财务 管理 页 面 ， 首 先 通过 单 选 按钮 选择 要 管理 的 内 容 是 收入 或 是 支出 ， 然 后 选择 查 
| 询 的 条 件 ， 并 输入 查询 的 关键 字 ， 来 查询 具体 需要 管理 的 数据 ， 最 后 对 查询 的 数据 进行 修 
改 和 删除 操作 。 财 务 管理 界面 如 图 3.21 所 示 。 


<select name="type" size="1" id="select"> 
<option value=""> 请 选择 </option> 


| 财务 管理 | 

| 加 必 入 BD 支出 | 

| | 清洁 上 二 执 方式 闫 别 “但 辐 梧 | 

| 收入 爹 蜂 。 收入 类 别 收入 据 述 出 操作 设置 

| 1445 其 他 1 月 投资 上 修改 ”出 际 

| 其 他 收 修改 晤 除 

| 1500 其 他 站 2 个 疏 是 | 

| 图 3.21 财务 管理 界面 

| 财务 管理 表单 的 主要 元 素 如 表 3.10 所 示 。 

| 表 3.10 财务 管理 表单 元 素 

| 名 称 | 元 素 类 型 重要 属性 含义 
| _ formes form method="post" action="" onSubmit="return chkinput searchO0"” | 财务 管理 表单 
| ”check Tadio id="check" value="tb_income" checked="checked" 收入 选项 

| check radio value="tb outgo" id="check" 支出 选项 


type select <option value="1"> 时 间 </option> 查找 方式 
<option value="2"> 类 别 </option> 
</select> 
ke text id="textfield" size="15" 查询 关键 字 
| Submit submit value=" 查 询 " id="Submit" “查询 ”按钮 


财务 管理 的 实现 过 程 如 下 。 
(1) 应 用 JavaScript 脚本 自 定义 一 个 chkinput_search 0 函数 ， 实 现 对 表单 提交 的 信息 
进行 验证 ， 代 码 如 下 : 
代码 位 置 : 配套 资源 \mr\03\ cwgl.php 
01 <script language="javascript"> 


02 function chkinput_searchO{ 
| 03 if(formes.type.value—""){ 
| 04 alert( 请 选择 查询 条 件 ! '); 
| 05 formes .type focus0: 
| 06 return(false); 
| 07 } 
| 08 if(formes.key.value—""){ 
| 09 alert( 请 输入 查询 关键 字 ! 7); 
| 10 formes.key.focus(); 
】 .94. 


16 </script> 


(2) 将 表单 信息 提交 到 本 页 ， 在 本 页 中 对 提交 的 数据 进行 处 理 ， 连 接 数据 库 文件 ， 


接收 表单 信息 ， 


首先 对 单 选 按钮 进行 判断 ， 判 断 选择 的 是 收入 管理 还 是 支出 管理 ， 然 后 应 


用 mysql query0 函 数 向 服务 器 发 送 SQL 语句 ， 检 索 与 查询 关键 字 相 匹配 的 信息 资源 并 且 
只 显示 8 条 记录 ， 代 码 如 下 : 
代码 位 置 : 配套 资源 \mr\03\ cwgl.php 


01 <?php 

02 iisset($ POST[check]) && $ POST[check] 一 "tb income" && $ POSTT'Submit]!=""){// 对 单 选 框 
与 查询 按钮 进行 判断 

03 > 

04 <?php 

05 include_once("conn/conn.php"); // 连 接 数据 库 文件 

06 $type=$_POST['type']; 

07 $key=$_POST['key']; 

08 if($type—1){ 

09 // 查 询 最 新 的 8 条 收入 记录 

10 $sql=mysql query("select * from tb_income where srsj like '%".$key."%' order by 
id limit 8",$conn); 

11 }elseif($type—2){ 

I $sql=mysql_ query("select * from tb_income where lb like '%".$key."%'order by id 
limit 8",$conn):; 

13 } 

14 S$info=mysql fetch_array($sq]); 

15 这 $info 一 false){ /如 果 $info 的 值 为 空 ， 则 说 明 没有 查询 记录 

16 > 


(3) 用 do...while 循环 语句 输出 收入 信息 与 查询 关键 字 相 匹配 的 信息 资源 ， 其 主要 代 


人 码 如 下 : 


代码 位 置 ， 配套 资源 \mr\03\ cwgl.php 


01 <php 
02 if($info—false){ 


03 ?> 


04 
05 


<tr> 


<td colspan="6" ><?php echo "<br><br><div align=center> 对 不 起 , 没有 查找 到 您 要 查找 的 


内 容 ! </div>"?2></td> 
06 ”<?php }else{ ”// 如 果 $info 的 值 不 为 空 ， 显 示 所 有 收入 记录 信息 


07 
08 
09 
10 
11 


do{?> 
<tr> 
<td bordercolor="#FFFFFF" bgcolor="#EFFFFF"><?php echo $info['stje'];?> </td> 
<td bordercolor="#EFFFFF" bgcolor="#FFFFFF"><?php echo $info["lb'];?> </td> 
<td bordercolor="#FFFFFF" bgcolor="#EFFFFF"><?php echo $info['srms']:?> </td> 
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(4) 单 击 输出 的 收入 信息 后 面 的 “修改 ” 超 链 接 ， 将 弹出 收入 信息 修改 页 ， 当 用 户 
| 对 收入 信息 修改 完成 后 ， 单 击 “ 修 改 ” 按 钮 ， 进 入 到 收入 信息 的 修改 处 理 页 ， 在 该 处 理 页 


| 获取 表单 中 隐藏 域 传递 过 来 的 ID 号 ， 从 数据 库 中 查询 出 对 应 的 数据 ， 应 用 update 语句 完 


成 数据 的 更 新 操作 。 修 改 收入 信息 的 处 理 页 代码 如 下 : 
代码 位 置 ， 配套 资源 \mr\03\ addtype.php 


| 12 <td bordercolor="#FFFFFF" bgcolor="#FFFFFF"><?php echo $info['srsj]:2?> </td> 
| 13 </> 
| 14 <2php 
| 15 }while(Sinfo=mysql_fetch_array($sqD)); 
#1 | 16 
| 1 
| 18 <?php 
be | 1 
| 2 


01 <2php 

02 include once("conn/conn.php"); // 包 含 数据 库 文件 

03 $id=$ GET["checks id"]: // 获 取 传 递 修改 连接 的 id 
04 S$tables=$ GET["type"]; // 获 取 单 选 按 钮 的 值 

05 $sql=mysql_query("select * from $tables where id=".$id.""); /查询 指定 要 修改 的 数据 
06 S$info=mysql fetch_array($sqD; // 获 取 查 询 结果 

07 ifisset($_POST["Submit"]){ /判断 提交 按钮 的 值 是 否 存在 
08 $ms=trimn($_ POST['smms]): /获取 表单 提交 的 数据 

09 $je=$_ POST['seje]; 

10 $sj=$_POST['srsi']; 

11 Syear=substr($sj,0,4); // 利 用 substr0 对 收入 时 间 中 的 年 进行 截取 
12 Smonth=substr($sj,5,6); 

13 $lb=$_ POST['select]: 

14 这 mysql query("update tb_income set srms='$ms',srje='$je',srsj="$sj',lb="$1b', 


15 year='$year',month='$month' where id=".$_POST["id"]."",$conn)){ // 执 行 更 新 语句 
| 16 echo "<script>alert(' 收 入 更 改 成 功 !):window.location.hre 人 ='index.php?link".urlencode(" 财 务 
| 管理 ").";</script>"; 


17 yelse{ 
18 echo "<script>alert( 收 入 更 改 失 败 ! ):historybackO:</script>"; 
| 19 } 
| 20 exit: 
区 


| > 
(5) 单 击 输出 的 收入 信息 后 面 的 “删除 ” 超 链接 ， 根 据 超 链接 传递 的 收入 ID 号 ,将 
| 数据 库 中 对 应 的 记录 找到 并 删除 。 删 除 收入 信息 的 处 理 页 代码 如 下 : 

代码 位 置 : 配套 资源 mr\03\ delcwsrphp 


01 <?php 
02 include once("conn/conn.php"): // 连 接 数 据 库 
03 $id=$ GET["del id"]; // 获 取 超 链接 传递 的 儿 号 


04 if(mysql query("delete from 也 _income where id=".$id."",$conn)){ /执行 删除 语句 
05 echo "<script>alert( 该 收入 删除 成 功 ! )windowjlocation href-indexphp?link= "urlencode(" 添 加 
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收入 7).";</scripf> 
06 }else{ 
07 echo "<script>alert(' 该 收入 删除 失败 ! ):history.backO:</script>": 
08 } 
09 > 
说 明 : 


支出 管理 与 收入 管理 过 程 相同 ， 这 里 不 再 黄 述 。 具 体内 容 请 参考 本 书 配套 资源 源码 。 


3.6.7 ”财务 查询 实现 过 程 


用 户 登录 后 ， 单 击 “ 理 财 助 手 ”/“ 财 务 查 询 ” 超 链接 ， 可 进入 到 财务 查询 页 面 。 财 务 
查询 页 面 的 运行 结果 如 图 3.22 所 示 。 在 该 页 面 中 可 以 按 某 一 时 间 段 进行 查询 , 查询 结果 为 | 
这 一 段 时 间 内 的 收入 总 额 、 消 费 总 额 及 余额 。 | 


财务 查询 


查询 日 期 : 2011-01-01 图 至 2011-12-31 回 国 司 


收入 金额 支出 金额 余额 


118255 | 6210 112045 


图 3.22 财务 查询 界面 | 
财务 查询 是 对 指定 时 间 段 的 数据 查询 ， 在 SQL 语句 中 ， 对 指定 范围 内 的 数据 进行 查 
找 可 以 通过 以 下 两 种 方式 实现 。 | 
(1) 通过 关键 字 between...and... 实 现 ， 其 语法 格式 如 下 : 
select 要 查找 的 字段 from 表 名 where 字段 名 between 初始 值 and 终止 值 
(2) 通过 比较 运算 符 实现 ， 其 语法 格式 如 下 : 
select 要 查找 的 字段 from 表 名 where 字段 名 > 初始 值 and 字段 名 < 终止 值 


说 明 : 
财务 查询 模块 中 采用 的 是 第 一 种 方式 。 


在 对 指定 时 间 段 的 收入 金额 进行 求 和 时 ， 应 用 sum0 函 数 实现 ， 该 函数 的 使 用 方法 如 下 : 
sum([all | distinct] expression) 
参数 说 明 : 
回 all， 表示 对 指定 字段 的 所 有 值 进行 聚集 函数 运算 ，all 为 默认 值 ， 如 果 省 略 参数 | 
all 或 distinct， 则 表示 对 指定 字段 的 所 有 记录 进行 聚集 运算 。 | 
回 distimnct: 表示 对 指定 字段 的 所 有 非 重 复 记 录 进 行 求 和 。 | 
expression: 是 精确 数字 或 近似 数字 数据 类 型 分 类 (bit 数据 类 型 除外 ) 的 表达 式 。 | 
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的、 
WT 

sum() 函 数 的 返回 值 类 型 如 表 3.11 所 示 。 

表 3.11 sum() 函 数 的 返回 值 类 型 


表达 式 结果 返回 值 类 型 
整数 分 类 int 
decimal 分 类 decimal 
Imoney 和 smallmoney 分 类 money 
float 和 real 分 类 float 


财务 查询 的 实现 过 程 如 下 。 
(1) 创建 财务 查询 的 表单 affairsqueryphp， 表 单 主要 元 素 如 表 3.12 所 示 。 
表 3.12 财务 查询 表单 元 素 


重要 属性 
action="" method="post" id="form" onsubmit="return 
chkinput(this)" 


含 
财务 查询 表单 


查询 起 始 时 间 
查询 结束 时 间 
提交 表单 按 饥 


义 


Submit Value=" 查 询 " id="Submit" 


(2) 通过 chkinput0 函 数 验 证 文本 框 元 素 是 否 为 定 ， 其 主要 代码 如 下 : 
代码 位 置 ， 配 套 资源 \mr\03\ affairsqery.php 


01 <script language="javascript"> 
02 function chkinput(form){ 


03 if(form.p_datel.value—""){ 
04 alert(" 请 输入 起 始 日 期 1"); 
05 form.p_datel.selectO: 
06 return(false); 

07 } 

08 if(form.p_date2.value—""){ 
09 alert(" 请 输入 终止 日 期 1"); 
10 form.p_date?2.select(); 

11 return(false); 

2 } 

13 retum(true); 

14 » 

15 </script> 


(3) 当 接 收 到 查询 的 起 始 时 间 和 终止 时 间 后 ， 生 成 查询 语句 ， 执 行 SQL 语句 并 返 区 
查询 结果 。 如 果 没 有 查找 到 任何 结果 ， 则 输出 “没有 查找 到 您 要 找 的 内 容 !”， 其 关键 代码 
如 下 : 

代码 位 置 ， 配 套 资源 \mx\03\ affairsqery.php 


01 <?php 
02 ”if($_POST['Submit]!=""){ // 判 断 “ 查 询 ” 按 钮 
030 73 
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04 <table width="515" border="1" cellpadding="1" cellspacing="1" bordercolor="#FF6699"> 


05 <tr> 
06 <td width="171"><div align="center" class="STYLE8"> 收 入 金额 </div></td> 
07 <td width="172"><div align="center" class="STYLE8"> 支 出 金额 </div></td> 
08 <td width="172"><div align="center" class="STYLE8"> 余 额 </div></td> 贪 起 
09 </tr> 一 一 
10 ”<?php 
11 S$from=-$ POST[p datel1]; // 调 用 查询 的 起 始 时 间 | 
12 S$to=$_ POST['p_date2']; // 调 用 查询 的 结束 时 间 | 
13 include once("conn/conn php"): /连接 数据 库 | 
14 $sql=mysql_query("select sum(stje) as sr from tb_income where srsj between '$from' and | 
'$to™", $conn); | 
15 $sqls=mysql query("select sum(zcje) as zc from tb_outgo where zcsj between '$fronmy' | 
and '$to"™", $conn); | 
16 Sinfo=mysql fetch_array($sql); // 获 取 查 询 结果 | 
17 $infos=mysql fetch_array($sqls); // 获 取 查 询 结果 | 
18 这 $info 一 false && $infos 一 false){ | 
19 > | 
20 <tr> ! 
21 <td colspan="3"><div align="center"> 没 有 查找 到 您 要 找 的 内 容 !</div></td> | 
22 </tr> ! 
23 <?php | 
24 j}else 这 $info 一 false && $infos=——true){ | 
25 dof | 
2607> | 
27 <tr> | 
28 <td><div align="center" class="STYLE9"></div></td> | 
29 <td><div align="center" class="STYLE9"><?php echo $infos['zc'];?></div></td> | 
30 <td><div align="center" class="STYLE9"><?php echo $infof'sr]-$infos['zc"]:?></div></td> | 
31 </t> | 
32 <?php ! 
33 }while($info=mysql fetch_array($sql)); | 
34 }else{ | 
35 dof | 
36 Fa | 
37 <tr> | 
38 <td><div align="center" class="STYLE8"><?php echo $info['sr]:?></div></td> | 
39 <td><div align="center" class="STYLE8">< ?php echo $infos['zc]:2></div></td> ! 
40 <td><div align="center" class="STYLE8"><?php echo $info['sr']-$infos['zc'];?> | 
</div></td> | 
41 </tr> | 
42 <Iphp | 
43 }while($info=mysql fetch array($sql)): | 
2 | 
46 </table> | 
47 ”<?php | 
20 | 
49 > | 
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3.6.8 ”财务 统计 实现 过 程 


财务 统计 主要 是 按 年 统计 某 一 年 的 消费 金额 。 首 先 通 过 下 拉 列 表 框 选择 要 统计 的 年 
a | 份 ， 然 后 单 击 “ 提 交 ” 按 钮 ， 即 可 将 该 年 的 消费 情况 查找 出 来 ， 并 且 输 出 该 年 每 月 的 消费 


有 情况 ， 运 行 结果 如 图 3.23 所 示 。 


100 
2011 年 总 收入 118255 元 支出 6210 元 剩余 112045 元 


图 3.23 财务 统计 显示 界面 
| 由 于 在 财务 统计 页 面 中 要 通过 下 拉 列 表 框 选择 要 统计 的 年 份 ， 因 此 可 以 手动 在 
| <option> 与 </option> 标 记 之 间 添 加 年 份 ， 但 这 会 增加 程序 开发 时 间 。 为 了 节省 开发 时 间 ， 
| 这 里 通过 JavaScript 脚本 来 实现 列表 框 中 时 间 的 添加 ， 其 主要 代码 为 : 
| 01 <script language="JavaScript" > 


02 for(i=1900;i<2050;i++) 
03 document.write('<option>"+1) 
04 </script> 


| 查询 一 年 的 消费 情况 ， 然 后 按 每 月 消费 情况 输出 ， 输 出 的 月 份 不 可 避免 地 会 出 现 重复 
| 的 记录 。 为 了 不 在 前 台 显 示 重 复 的 记录 ， 可 以 使 用 SQL 语句 的 关键 字 distinct， 该 关键 字 
| 的 格式 如 下 : 
| select distinct 字段 名 from 表 名 where 查询 条 件 


利用 distinct 关键 字 可 以 在 查询 结果 中 去 除 重复 行 ,与 其 对 应 的 还 有 关键 字 all, 在 SQL 
语句 中 加 入 关键 字 al， 表 示 显 示 所 有 的 记录 ， 如 果 SQL 语句 中 没有 这 两 个 关键 字 ， 查 询 
结果 中 将 显示 所 有 的 记录 。 


财务 统计 实现 的 代码 如 下 : 
代码 位 置 ， 配套 资源 \mr\03\ affairsstat.php 
01 <?php 
02 include once("conn/conn.php"): // 连 接 数 据 库 
03 iflisset($ POST['select]){ // 获 取 查 询 关 键 字 
04 $year=$_ POST!['select"]; 
105 
06 <table width="513" border="0" cellpadding="0" cellspacing="0"> 
07 <tr> 


了 。100 。 
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DS 

08 <td width="120" height="25" bordercolor="#FF9933"><div align="center" class="STYLE18"> 
月 份 <div></td> 

09 <td width="120" bordercolor="#FF9933"><div align="center" class="STYLE18"> 收 
入 </div></td> 

10 <td width="122" bordercolor="#FF9933"><div align="center"” class="STYLE18"> 支 
出 <div></td> 

11 <td width="123" bordercolor="#FF9933"><div align="center"” class="STYLE18"> 余 
额 </div></td> 

12 <?php 


13 ”人 * 利 用 distinct 关键 字 对 收入 的 数据 表 中 查询 的 月 份 进行 去 除 重复 月 份 */ 

14 $sql=mysql_query("select distinct month from tb income where year=".$year." order by 
month ",$conn); 

15 while($info=mysql fetch array($sqD){ // 循 环 输出 查询 结果 


16 $month=substr($info['month’],0,2); // 对 获取 的 月 份 字符 串 进行 截取 
17 = 

18 <tr> 

19 <td bordercolor="#FF9933"><?php echo substr($info['month'].0.2):2> </td> 
20 <?php 


21 ”A 利用 sum0 对 提交 的 年 份 进行 求 和 */ 

2 $sr=mysql_query("select sum(srje) as sr from tb_income where year=".$year." and month like 
'$month%",$conn); 

23 S$info_sr=mysql fetch array($sr); 


24 if($info_sr['sr']==false){ // 如 果 收 入 的 金额 为 空 
25 echo "0"; // 则 输出 数字 为 0 

26 }else{ 

2 echo $info_sr['sr]: 

28 } 

29 > 

30 <?php 


31$zc=mysql query("select sum(zcje) as zc from tb_outgo where year=".$year." and month like 
‘$month%", $conn); 


32 S$info zc=mysql fetch array($ze); /获取 支出 统计 数据 
33 这 $info_zc['zc] 一 false){ 

34 echo "0": 

35 }else{ 

36 echo $info_zc['zc']: // 输 出 支出 数据 
57 人 

38 > 

39 <2php 

40 if($info sr[sr]-$info_zc['zc] 一 false){ /计算 剩余 金额 
41 echo "0"; 

42 }else{ 

43 echo $info_sr['sr]-$info_zc['zc]:}?> ”// 输 出 余额 

4 </td></t> 

4 <?php 

450 

47 2 

48 </table> 

49 <?php 


de 


日 
Ey 


3.7-1 


了 这 和 全 二 
能 。 其 运行 效果 如 图 3.24 所 示 。 
1 2 le KR ons A: | 
[marae | ies 
最 UD [mee | 站: 者 8 从中 = 个 人 om: 加 
| shi: orn 1s oo 人 并: 清寺 提 
可 让 爱人 是 和 要 变 的 ， 侍 fi 人 是 他 于 你 ， 可 是 信 下 要 fi 和信 化 是 的 下 要 
日记 | 。 | 你 了， 从 至 催生 有 办 法 和 对 下 要 你 ;同和 的 ， 他 要 和 信也 洋 有 力 法 仍 半 你 。 
一 一 | 当 一 个 和 不要 俐 可 开 作 ， 人 要 癌 折 己 证 要 下 要 他 ， 如 果 你 也 下 
EIEEIEDO 略 让 eh: 
发 表 时 间 : 2011-04-36 11 47-07 分 类 : 心情 
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$sql2=mysql query("select sum(srje)as sr from tb income where year=-".$year”" ",$conn); 
$sql3=mysql query("select sum(zcje)as zc from tb_outgo where year=".$year."",$conn); 
$info2=mysql fetch array($sql2); 
S$info3=mysql fetch array($sql3):; 
> 
<?php echo $ POST['select]:?> 年 总 收入 
<2php 
if($info2['sr']=—false){ 
echo "0": 
}else{ 
echo $info2['sr']; 
}?> 元 支出 


<2php 
if($info3['zc']==false){ 
echo "0": 
}else{ 
echo $info3['zc']; 
}?> 元 剩余 
<?php 
这 $info2['sr]-$info3['zc] 一 false){ 
echo "0"; 
}else{ 
echo $info2['sr']-$info3['ze"]; 
}?> 元 
<2php }?> 


3.7 我 的 日 记 模块 设计 


我 的 日 记 模块 设计 概述 


对 一 个 网 络 日 记 系 统 来 说 ,“ 我 的 日 记 ” 是 最 基本 的 功能 ， 但 同时 也 是 最 复杂 的 一 个 
功能 。 我 的 日 记 模块 包括 “添加 日 记 ” “查看 日 记 ”“ 查 询 日 记 ” 和 “删除 日 记 ”4 大 功 


人 1 樟 社 是 早上 能 玉 ,看 到 | 一 拉 阳 江 信 好 芝 到 杖 过 。 可 以 不 二 急 者 起 床 ， 知 在 被 寅 里 听 首 反 妈 在 
同房 里 径 手 各 类 M9 外 妇 ， 不 一 会 儿 疹 外 重活 汗 汪 淄 了 整个 守 月 。 作 . 幸 往 束 是 宗 着 白色 的 棉 有 
长 卉 走 在 华 条 初 上 的 信 赃 ， 经 过 一 字音 食 EEH 正 弛 响起 一 普 久 过 的 

1 天 并 4 文 


共有 窗 言 3 条 和 页 旦 示 2 条 第 1 页 / 闪 > 页 首页 上 -页 下 -页 慌 页 


图 3.24 我 的 日 记 模 块 


102s 
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3.7.2 ”过 滤 敏 感 词 


很 多 论坛 、 评 论 、 贴 吧 都 有 过 滤 敏 感 词 的 功能 。 过 滤 敏 感 词 通常 使 用 一 对 一 的 过 滤 形 | 
式 。 如 要 过 滤 “ 色 情 ” 这 个 词汇 ， 就 要 考虑 内 容 里 边 是 否 包含 “色情 ”这 个 词 。 对 于 敏感 | 
词 的 过 滤 ， 本 项 目 中 使 用 正则 表达 式 preg_match0 函 数 实 现 。 | 
preg_match() 函 数 用 来 在 字符 串 中 搜索 所 有 与 给 出 的 正则 表达 式 相 匹配 的 内 容 ， 如 果 
存在 ， 则 返回 True; 否则 ， 返 回 False。 其 语法 格式 如 下 : | 
int preg_match ( string pattern, string subject [, array matches [, int flags]] ) | 
preg_match0 函 数 的 参数 说 明 如 表 3.13 所 示 。 | 
表 3.13 ”preg_match() 函 数 的 参数 说 明 | 
说 明 | 
必要 参数 。 需 要 匹配 的 正则 表达 式 | 
必要 参数 。 输 入 的 字符 串 | 
可 选 参 数 。 输 出 的 搜索 结果 的 数组 ， 例 如 $out[0] 将 包含 与 整个 模式 匹配 的 结果 ，S$out[1] | 
将 包含 与 第 一 个 捕获 的 括号 中 的 子 模式 所 匹配 的 结果 ， 依 此 类 推 
可 选 参 数 。 标 记 : PREG_OFFSET_CAPTURE， 对 每 个 出 现 的 匹配 结果 也 同时 返回 其 附 
属 的 字符 串 偏 移 量 ， 本 标记 自 PHP 4.3.0 起 可 用 


本 项 目 中 实现 过 滤 敏 感 词 的 方法 如 下 。 | 

(1) 应 用 file0 函 数 读 取 存 储 在 文本 文件 中 的 敏感 词汇 〈 每 个 敏感 词 独立 成 一 行 )， 并 | 

将 其 存储 在 数组 $filter_word 中 。 | 
(2) 应 用 for 循环 语句 自动 读 取 数 组 元 素 ( 敏 感 词 )， 直 接 通 过 正则 表达 式 检验 用 户 | 

提交 的 日 记 是 否 含有 敏感 词 。 | 
(3) 当 用 户 提交 日 记 时 ， 将 日 记 内 容 与 存储 在 数组 中 的 敏感 词 进行 对 比 ， 如 果 提 交 | 

的 日 记 信息 中 含有 敏感 词 ， 将 弹出 提示 信息 ; 否则， 日 记 发 布 成 功 。 敏 感 词 过 滤 的 关键 代 | 
人 码 如 下 : | 
代码 位 置 ， 配套 资源 \mr\03\ chkappenddiary.php | 


01 ifGs file("./filterwords.txt"){ // 判 断 给 定 文件 名 是 否 为 一 个 正常 的 文件 “| 

02 Sfilter_word = 人 fle("./filterwords.txt"); /把 整个 文件 读 入 一 个 数组 中 | 

03 $str=-$_POST[wznr]: /获取 表单 提交 的 数据 | 

04 for($i=0;$i<count($filter_word);$i++){ /应 用 for 循环 语句 对 敏感 词 进行 判断 ”| 

05 @if(preg_match("/".trim(Sfilter_word[Si])."/i",Sstr)){ | 

// 浏 断 数据 中 是 否 含有 敏感 词 | 

06 echo "<script> alert(' 日 记 中 包含 敏感 词 ! "):history.back(-1);</script>"; | 

07 exit: | 

08 } | 

09 } | 

10 | 

< 关键 代码 解析 | 
@ preg _ matchO 函 数 中 的 “ji” ， 是 指 在 进行 敏感 词汇 比较 时 不 区 分 字母 大 小 写 。 

.103 。 \ 
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| (4) 在 用 户 提 交 日 记 信息 后 ， 系 统 将 添加 的 日 记 信 息 与 本 模块 设 定 的 敏感 词 进 行 一 
| 一 对 比 ， 如 果 在 用 户 填写 的 日 记 信息 中 存在 敏感 词 ， 例 如 “黄色 ”， 就 会 弹出 日 记 中 含有 
| 敏感 词 的 警告 信息 ， 效 果 如 图 3.25 所 示 。 


| 
全 A 2 
| SE A NEE a 


文章 主题 : 夏天 未 了 


| 分 类 : 杂记 ~ 
es 


验证 码 ; 803 


| 图 3.25 过 滤 敏 感 词 “ 黄 色 ” 
| 3.7.3 ”当前 页 完成 验证 码 的 验证 


验证 码 技术 是 为 了 防止 用 户 名 被 暴力 破解 ， 而 在 添加 页 面 中 要 求 输入 验证 码 , 通常 情况 
下 ， 如 果 输 入 的 验证 码 错误 ， 将 重新 刷新 页 面 ， 所 添加 的 日 记 信息 被 清空 ， 这 样 给 用 户 操作 
造成 了 一 定 的 麻烦 。 为 了 避免 这 一 现象 的 发 生 ， 本 项 目 在 实现 添加 日 记 信息 时 ， 验 证 码 在 当 
| 前 页 进行 验证 ， 即 使 验证 码 输 入 错误 ， 也 不 会 丢失 填写 的 日 记 信 息 ， 效 果 如 图 3.26 所 示 。 


| 
| 
| 
! 
| 
| 
| 便 
| 三 人 入 > = 
| 上 度 一 生 的 人 。 首 辐 
| 感觉 ， 所 以 才 叱 
| 省 什 么 是 你 必要 
| 
， 你 最 要 的 ， 信 
! ， 山 信 不 是 你 各 有 
| 
| 
1 
1 
| 
| 
| 
1 
| Ve 
| 文章 主题， 下 玫 让 于 全 玖 三 个 人 
罗 类 :情感 ~ 
二 本 四 ee 委 5 局 
eoe@ ec 名 EJ 
有 人 总 ， 人 生 就 是 为 了 找寻 要 的 过 程 ， 大 直人 的 大生 部 雪 扩 到 三 人。 天 
一 个 是 在 最 要 的 人 ， 到 十 是 最 要 你 的 人 ， 第 三 个 是 共度 一 生 的 人 。 兰 目 
在 不 是 
在意 - 
BS 


| 图 3.26 验证 码 在 当前 页 验证 
J “104 ， 
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要 实现 在 当前 页 完成 验证 码 的 验证 ， 首 先 设置 验证 码 的 表单 元 素 ， 然 后 添加 一 个 隐藏 
域 ， 用 来 记录 随机 数 的 值 ， 代 码 如 下 : | 


<input name="checkcode" type= "text" id="checkcode" size="12"> 
<input type="hidden" name="createcheckcode" value=""> 


1， 获 取 验 证 三 
验证 码 通过 Math.random0 函 数 生成 随机 数 的 方式 得 到 。Math.round0 函 数 可 以 获取 指 | 
定 范围 内 的 随机 数 。 在 发 表 日 记 页 面 上 生成 一 组 4 位 的 随机 数 ， 代 码 如 下 : | 
<script language="javascript"> 
var num1=Math.round(Math.random()*10000000); 
var num=num!l toString().substr(0,4); 
document.form!l .createcheckcode.value=num:; 
document.write("<img name=codeimg4 src='checks.php?num="+num+">"); 
</script> 


2. 显示 随机 数 图 片 


显示 随机 数 的 方式 很 多 ， 将 随机 数 写 入 一 个 图 片 中 再 显示 是 目前 常用 的 方法 。 在 PHP | 
中 ， 可 以 使 用 GD2 函数 库 来 实现 。GD 函数 库 包含 的 函数 介绍 如 下 。 | 

加 ”imagecreate0) 函 数 

imagecreate() 函 数 用 来 创建 一 个 基于 调 色 板 的 空白 图 像 源 ， 这 是 生成 图 片 的 第 一 步 。 
函数 语法 如 下 : 

resource imagecreate ( int width, int height ) 

其 中 ， 参 数 width 和 height 分 别 指定 了 图 像 的 宽 和 高 。 

加 ”imagecolorallocate0 〇 函数 

imagecolorallocate() 函 数 可 以 为 创建 后 的 图 像 分 配 颜 色 。 函 数 语法 如 下 : 


int imagecolorallocate ( resource image, int red, int green, int blue ) 


其 中 ,参数 image 是 一 个 图 像 源 : red、green 和 blue 则 表示 红 、 黄 、 蓝 三 元 素 的 成 分 。 | 
每 种 颜色 的 取 值 范围 在 1~255 之 间 。 | 
加 ”imagestring() 函 数 | 

图 像 创 建 完成 后 ， 就 可 以 使 用 imagestring0 函 数 来 添加 图 像 文字 了 。 该 函数 的 语法 如 下 : | 

bool imagestring ( resource image, int font, int x, int y, string s, int col ) | 


其 中 ， 参 数 image 是 一 个 图 像 源 ， 参 数 font 可 以 设置 字体 ， 如 果 使 用 系统 默认 字体 ， | 
可 以 使 用 1~5 的 数字 ， 参 数 x 和 y 分 别 表示 文字 相对 于 整 幅 图 像 的 x 轴 和 y 轴 坐 标 ， 即 | 
所 输入 的 字符 串 的 左上 角 坐 标 ， 参 数 s 就 是 要 显示 的 字符 串 ， 参 数 col 为 字体 颜色 ， 同 样 | 
使 用 imagecolorallocate() 函 数 来 分 配 。 | 

imagepng(0 〇 函数 

imagepng() 函 数 将 创建 完成 的 图 片 以 .png 的 格式 输出 。 函 数 语法 如 下 : 


。105 。 L_ 
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ee 
| bool imagepng ( resource image [., string filename] ) 

其 中 ， 参 数 image 是 要 保存 的 图 像 源 ; 参数 flename 是 要 保存 的 图 像 名 ， 如 果 省 略 ， 
则 直接 输出 到 浏览 器 。 

imagedestroyO 函 数 

图 像 保存 完毕 后 ， 使 用 imagedestroy0 函 数 来 释放 内 存 。 

应 用 GD 函数 库 生 成 随机 图 片 的 实现 代码 如 下 : 

代码 位 置 : 配套 资源 \mr\03\ checks.php 


| 01 <?php 
| 02 session_start(); // 启 动 session 会 话 
| 03 header("content-type:image/png"); // 设 置 创 建 图 像 的 格式 
| 04 Simage width=70; // 设 置 图 像 宽度 
05 Simage height=18; // 设 置 图 像 高 度 
06 


07 $new_number=$_GET[num]; 
08 ”$num image-imagecreate($image_width,$image_height); /创建 一 个 画布 


09 imagecolorallocate(Snum image,255,255,255); // 设 置 画布 的 颜色 

10 

11 for($i=0:$i<strlen($new_number):$i++){ // 循 环 读 取 session 变量 中 的 验证 码 
12 $font=mt_rand(3,5); // 设 置 随机 的 字体 

13 Sx=mt_rand(1,8)+$image_width*$i/4; // 设 置 随机 字符 所 在 位 置 的 x 坐标 
14 S$y=mt_rand(1,$image_height/4); // 设 置 随机 字符 所 在 位 置 的 y 坐标 
15 // 设 置 字符 的 颜色 

16 S$color=imagecolorallocate($num_image,mt_rand(0,100),mt_rand(0,150),mt_rand(0,200)):; 
7 imagestring($num_image, $font,$x,$y,$new_number[$i],$color); /水 平 输出 字符 
18 : 

19 imagepng($num image); // 生 成 .png 格式 的 图 像 

20 imagedestroy($num image); // 释 放 图 像 资 源 

21 > 


3， 执行 验证 操作 


提交 表单 信息 后 ， 调 用 自 定义 函数 check formm0) 来 实现 在 当前 页 验证 输入 的 验证 码 是 
| 否 正确 。 代 码 如 下 : 

| 代码 位 置 ， 配套 资源 \mr\03\ appenddiary.php 

| 01 <script language="javascript"> 

| 02 function check form(forml){ 


03 这 forml.checkcode .value 一 ""){ /如 果 验 证 码 为 空 
| 04 alert(" 验 证 码 不 能 为 室 ! ");forml.checkcode.focus();return false; 


06 if(form!1.checkcode.value!=num){ // 如 果 输 入 的 验证 码 的 值 与 随机 的 验证 
码 的 值 不 相等 
07 alert(" 您 输入 的 验证 码 不 正确 , 重新 输入 !"):forml.checkcode.focusO:returm false; 
08 } 
09 } 
10 </script> 


* 106: 
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3.7.4 查询 关键 字 描 红 


在 查询 日 记 中 体现 了 方便 快捷 的 人 性 化 原则 ， 为 了 方便 浏览 者 查阅 信息 ， 便 于 查找 与 | 
浏览 者 的 关键 字 相 符合 的 信息 ， 要 在 搜索 中 添加 描 红 功 能 | 
查询 关键 字 描 红 是 指 将 查询 关键 字 以 特殊 的 颜色 、 字号 或 字体 进行 标识 ， 这 样 可 以 使 | 
浏览 者 快速 找到 所 需 的 关键 字 ， 方 便 用 户 从 搜索 结果 中 查找 所 需 内 容 。 查 询 关 键 字 描 红 适 | 
用 于 模糊 查询 。 下 面 介绍 如 何 实现 查询 关键 字 描 红 。 | 
本 项 目 使 用 str_ireplaceO) 函 数 来 替换 查询 关键 字 ， 当 显示 所 查询 的 相关 信息 时 ， 将 输 | 
出 的 关键 字 替 换 为 红色 。 描 红 功 能 的 业务 流程 如 图 3.27 所 示 。 


从 


用 户 


设置 查询 条 件 


将 关键 字 描 红 


图 3.27 查询 关键 字 描 红 流 程 | 
ee wh | 
。 该 函数 的 语法 如 下 : | 


mixed str_ireplace ( mixed search, mixed replace, mixed subject [, int &count]) 


该 函数 将 所 有 在 参数 subject 中 出 现 的 参数 search 以 参数 replace 取代 ， 参数 &count 才 | 
示 取 代 字 符 串 执行 的 次 数 。 | 
str_ireplace() 函 数 的 参数 说 明 如 表 3.14 所 示 。 


表 3.14 str_ireplace() 函 数 的 参数 说 明 


参数 说 了 明 

search 必要 参数 ， 指 定 需要 查找 的 字符 串 
replace 必要 参数 ， 指 定 替 换 的 值 

subject 必要 参数 ， 指 定 查 找 的 范围 
count 可 选 参数 ， 获 取 执 行 蔡 换 的 数量 


注 尽 : | 
str_ireplace() 函 数 在 执行 替换 操作 时 是 不 区 分 大 小 写 的 。 如 果 需 要 对 大 小 写 加 以 区 分 ， | 
可 以 使 用 str_replace(O) 函 数 。 
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人 Bi 项 目 业 例 分 析 


在 本 项 目 中 查询 关键 字 描 红 的 关键 代码 如 下 : 
<table width="515" border="0" cellpadding="0" cellspacing="0"> 


<td width="405"> 文 章 主 题 : 


04 <?php echo str_ireplace(Skeyword,"<font color='#FF0000'>".Skeyword."</font>", Sinfo 
["wzzt]);2> </td> 


<td width="110"> 分 类 : 


<?php echo str_ireplace(Skeyword,"<font color='#FF0000'>".Skeyword."</font>", Sinfo 


</tr> 
<tr> 
<td colspan= "2"> 


< ?php echo str_ireplace(Skeyword,"<font color='#FF0000'>".Skeyword."</font>", Sinfo 
['wznr']);?> </td> 


</tr> 


</table> 
如 果 在 文章 标题 、 类 别 和 内 容 中 存在 查询 的 关键 字 , 那么 对 其 中 的 关键 字 进 行 描 红 输出 。 


当 用 户 登 录 后 ， 单 击 “ 我 的 日 记 ”/“ 添 加 日 记 ” 超 链接 ， 
(appenddiary.php )。 添 加 日 记 页 面 的 运行 结果 如 图 3.28 所 示 。 


发 表 日 记 
文章 主题 ， 走 进 你 生命 中 的 三 个 人 
分 类 ; 情感 ~ 
bon 0 o0 o8 0 加 
9 o o% o@05 od 
有 人 说 ， 人 生 就 是 为 了 找寻 爱 的 过 程 ， 拇 个 人 的 人 生 都 要 找到 三 个 人 。 


守 是 各 着 妆 的 人 0 第 二 个 是 盘 爱 你 的 人 ， 第 三 个 是 共度 一 生 的 人 。 首 
Eh ， 然 后 体会 到 爱 的 感觉 ! 因为 所 以 才能 
找 
敲 


感觉 ， 
人 当 你 经 历 过 要 人 与 被 要 ， Et 才 会 知 通 什么 是 你 需要 
到 最 适合 你 ， 能 够 相处 一 整 子 的 人 
的 ， 在 现实 生活 中 ， 这 三 个 人 通常 不 是 同一 个 人 ; 你 最 要 的 ， 
人 往往 趟 重生 多， 而 最 长 的 ， 避 信 时 各 人 
不 是 最 要 你 的 ， 只 是 在 最 适合 的 时 间 出 现 的 那个 人 。 
验证 码 : 830| 8383 


B® 


图 3.28 添加 日 记 页 面 的 运行 结果 


吉安 当 小 


实现 过 程 如 下 。 
CL 派 加 日 记 页 为 一 个 发 布 表单 ， 包括 文章 主题 、 分 类 、 文 章 内 容 等 元 素 。 部 分 表 
单元 素 如 表 3.15 所 示 。 


表 3.15 添加 日 记 页 面 的 主要 表单 元 素 


元 素 类 型 重要 属性 


| method="post" action="chkappenddiary.php" 


1d="textfield" 


* 108 。 


可 进入 到 添加 日 记 页 
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Ss 
续 表 
名 称 | 元 素 类 型 重要 属性 含义 
<select name="fl" size="1" id="select"> 
<option> 请 选择 </option> 
fl 人 日 记分 类 
<option value=" 杂 记 "> 杂 记 </option> 
</select> 
Sk a " id="l" value="&ltimg src='images/xq/].gif &et:" 心情 
checked="checked" 
Wznr textarea cols="70" rows="10" id="textarea" 文章 内 容 
checkcode | text id="checkcode" size="12" 验证 码 
checkbox checkbox id="checkbox" value="1" 是 否 为 私 帖 
| src="images/1 1.png" onclick=" return check form “确定 ”图 标 
(formml)" | 
imageField2 | image SIC="images/22.png" onclick="formresetO:return false:" “取消 ”图 标 


(2) 通过 JavaScript 脚本 验证 表 咎 
代码 位 置 ， 配套 资 源 \mr\03\ appenddiary.php 


01 
02 
03 


(3) 提交 表 自 


<script language="javascript"> 
function check_form(forml){ 


和 元素 是 否 为 空 ， 其 主要 代码 如 下 所 示 ; 


if(form!1 .topic.value—""){ 
alert(" 文 章 主题 不 能 为 空 ! ");forml.topic.focus(:return false; 


} 


这 forml.wznrvalue 一 ""){ 
alert(" 内 容 不 能 为 空 !);forml.wznrfocusO:retum false; 


} 


if(form!1 .checkcode.value—""){ 


alert(" 验 证 码 


不 能 为 空 ! "):forml.checkcode.focus():;return false; 


9 
if(form!1 .checkcode.value!=num){ 


alert(" 您 输入 的 验证 码 不 正确 , 重新 输入 ! :formml.checkcode focusOxretum false; 


} 
} 
</script> 


信息 到 数据 处 理 页 (chkappenddiary.php)， 首 先 对 用 户 的 日 记 信 息 进行 


敏感 词 过 滤 ， 然 后 应 用 $_POSTO 方 法 接收 用 户 提交 的 日 记 信息 。 在 处 理 页 中 ,将 获取 的 文 


音标 题 、 文 章 分 类 、 心 情 、 文 章 内 容 等 参数 组 成 insert 语句 ， 


并 最 终 执 行 insert 语句 ， 将 


数据 添加 到 数据 表 中 。 如 果 添 加 信息 成 功 ， 系 统 返 回 到 本 页 ， 可 继续 执行 添加 操作 ; 如果 


添加 失败 ， 则 返 


代码 位 置 : 


01 
02 
03 
04 


回 到 上 一 步 。 程 序 的 关键 代码 如 下 : 


配套 资源 \mr\03\ chkappenddiary.php 


<?php 
session start: /初始化 session 变量 
include_once("conn/conn.php"); // 载 入 数据 库 连接 文件 


if (is file("./filterwords.txt")){ 


// 判 断 给 定 文件 名 是 否 为 一 个 正 
“T0909. 


常 


24 


25 


if(preg_match("/".trim(Sfilter_word[$i])."/i",Sstr)){ 


人 ip 项 目 业 全 分 析 


Sfilter_word = file("./filterwords.txt"); // 把 整个 文件 读 入 一 个 数组 中 


$str=$_ POST['wznr]: 


for($i=0;$i<count($filter_word);$1++){ // 应 用 for 循环 语句 对 敏感 词 进行 判断 


// 判 断 传递 的 留言 信息 中 是 否 含 有 


echo "<script> alert(' 日 记 中 包含 敏感 词 ! ):historyback(-1):</script>"; 


exit; 
} 
} 


S$zt=trim($_POST['topic"]); // 获 取 表 单 提交 的 数据 


$fl=$_POST['A]: 
$mood=$ POST[check]; 
$nr-$ POST['wznr]:; 
$mm=$ POST[mm']; 


$datetime=date("Y-m-d H:i:s"); /获取 系统 当前 时 间 
这 strlen(Szb>30){ // 浏 断 日 记 标题 是 否 符合 指定 的 要 求 


echo"<script>alert( 主题 字数 不 能 超过 15 个 汉字 '):history.backQ;</script>"; 


exit' 


} 
if(mysql_query("insert into tb jour(wzzt,rjfl,wznr,xq,time)values('$zt','$fl','$nr','$mood', 


echo"<script>alert(' 日 记 添 加 成 功 !");history.back0;</script>"; 


jelse{ 


echo"<script>alert( 日 记 添 加 失败 !):history.backO:</script>"; 


exilt; 


3.7.6 ”分 页 显示 日 记 列表 


单 击 “ 我 的 日 记 ”/“ 查 看 日 记 ” 超 链接 ， 将 显示 用 户 发 表 过 的 日 记 主题 


、 部 分 文章 内 


容 、 日 记分 类 以 及 心情 。 日 记 列表 页 面 (lookdiaryphp) 的 运行 结果 如 图 3.29 所 示 。 


星期 三 : 适当 锻炼 ， 保 持 身材 
日 记 列 表 
文章 主题: 幸福 的 乓 间 ， 你 拥有 几 个 人 必 情 : 加 
发 表 时 间 : 2011-04-26 11:47;07 分 类 : 心情 
习 0 幸福 就 是 早上 醒 来 ， 章 到 一 抹 阳 光 属 好 落 到 枕 边 。 可 以 不 用 急 着 起 床 ， 般 在 被 富 里 听 着 妈妈 在 
后 房 里 惰 手轻 用 的 念 碌 ， 不 一 会 儿 荷包 蛋 的 香味 弥漫 了 芭 个 房间 。 {2 幸福 就 是 穿着 白色 的 棉布 
长 裙 走 在 华灯 初 上 的 傍晚 ， 经 过 一 家 音像 店 时 正好 响起 一 首 久 志 的 


| 阅读 全 文 | 
文章 主题: 要 的 区 计 必 情 : 图 
发 表 时 间 : 2011-04-26 11.42:36 分 类 : 情怀 


曾经 看 到 这 样 的 一 个 故事 说 是 一 个 男孩 和 一 个 女孩 相爱 那 田 孩 爱 得 是 那样 的 深 那 样 的 切 似乎 他 的 
生命 只 有 这 个 女孩 每 天 男孩 总 会 奔 过 一 条 马 只 去 为 女孩 洋 早 点 然后 回来 为 女孩 狠心 烧 意 烧 好 了 才 
会 小心 的 吊 女 孩 起 床 而 女孩 子 总 是 会 在 男孩 子 的 喊 声 中 才 从 用 肛 睡 意 

| 阅读 全 文 | 


共有 留言 4 条 每 页 显示 2 条 第 2 页 / 共 2 页 “首页 上 一 页 下 一 页 展 页 


图 3.29 日 记 列表 页 面 的 运行 结果 
“V0's 
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日 记 列 表 页 面 使 用 分 页 技术 和 do...while 语句 循环 输出 日 记 相 关 信息 。 程 序 关键 代码 | 


如 下 : 
代码 位 置 : 配套 资源 \mr\03\ lookdiary.php 

01 <?php 
02 include once("conn/conn.php"); // 包 含 数据 库 连接 文件 
03 > 
04 <?php | 
05 分页/ | 
06 ilisset($_GET["page"]) ||!is_ numeric($_GET["page"])){ ”// 判 断 分 页 变量 是 否 存 在 | 
07 ”/* ”Spage 为 当前 页 ， 如 果 Spage 为 空 ， 则 初始 化 为 1 */ | 
08 $page=1; // 设 置 分 页 变量 初始 值 | 
09 jelsef{ | 
10 @Spage=intval(S_GET["page"]): 
11 } 
12 $sql="select count(*) as total from tb jour"; // 统 计 日 记 的 总 数 
13 $query=mysql query($sq)); 
14 S$infos=mysql fetch array($query); 
15 @$total=$infos["total’]; 
16 这 $total 一 0){ /判断 如 果 总 记录 数 等 于 0 输出 下 面 的 内 容 
17 echo "<div align=center> 对 不 起 ， 暂 无 日 记 ! </div>"; 
18 }else{ 
19 $pagesize=2; /定义 每 页 显示 两 条 记录 
20 if($total%$pagesize=—0){ 
21 Spagecount=intval(Stotal/Spagesize); // 计 算出 总 的 页 码 
22 Jyelse{ 
3 目 $pagecount=ceil(Stotal/Spagesize); 
24 } | 
25 $sql=mysql query("select * from tb jour order by time desc limit ".($page-1)* | 

$pagesize.",$pagesize ",$conn); | 
26 while($info=mysql fetch array($sqD)){ /循环 输出 分 页 查询 的 结果 
2 > 
28 <tr> 
29 <td width="432" > 文章 主题 : <?php echo $info['wzzt"]:?> </td> 
30 <td width="70" > 心情 : <?php echo $info[xq]:?> </td> 
3 </tr> 
32 <tr> | 
33 <td width="432" > 发 表 时 间 : <?php echo $info['time']:?></td> | 
34 <td height="23" > 分 类 : ”<?php echo $infofrjf]:2> </td> | 
35 </tr><?php | 
36 @$zf=iconv_strlen(Sinfo['wznr'],'gb2312"); // 对 文章 内 容 的 编码 格式 进行 | 
Eyl if ($zf>160){ // 判 断 文 章 内 容 的 长 度 是 否 超 过 指定 范围 | 
38 @echo iconv_substr($info['wznr'],0,160,'gb2312)."......"; | 

// 超 出 指定 长 度 ， 使 用 省 略 号 代替 | 

39 jelsef | 
40 echo $info['wznr]; // 否 则 直接 输出 文章 内 容 | 
41 I. | 
42 > </td> | 


a 


my 人 Pitp 项 目 案 们 分 六 


六 

43 </tr> 

44 ”<tr> 

45 <td><a href="#" onclick="javascript:window.open(updiaryphp?check id-<2php echo Sinfo 
[id];?>,",");"> | 阅读 全 文 |</td> 

45 </t> 

46 <?php 

47 上 

48 } 

49 > 

50 


51 ”<!-- 创建 分 页 超 链接 --> 

52 ”<td valign="bottom"> 共 有 留言 &nbsp;<?php echo $total;?>&nbsp; 条 &nbsp; 

53 ”每 页 显示 &nbsp:;<?php echo $pagesize:?>&nbsp: 条 &nbsp; 

54 ”第 &nbsp;<?php echo $page;?>&nbsp; 页 / 共 &nbsp;<?php echo $pagecount?>&nbsp; 页 


55 <ahref="<?php echo $ SERVER["PHP SELF"]?>?page=1" class="al"> 首 页 </a>&nbsp; 

56 <a href-"<?php echo $ SERVER["PHP SELF"]?> 

57 ?page=<?php if($page>1) echo $page-1; else echo 1; ?>" class="al"> 上 一 页 </a>&nbsp; 

58 <ahref="<Iphpecho $ SERVER["PHP SELF"]?> 

59 ?page=<?php if($page<$pagecount) echo $page+1; else echo $pagecount; ?>" class="al"> 下 


60 <a hre 合 "<?php echo $ SERVER["PHP SELF"] ?>?page=<?php echo $pagecount:?>" 
class="al"> 尾 页 </a></td> 


< 关键 代码 解析 

@ ”intval: 对 页 码 进行 取 整 。 

四 S$total: 数据 库 中 的 日 记 总 数 。 

目 ceil: 对 日 记 记 录 总 数 除 以 一 页 显示 的 记录 数 进行 取 整 ， 如 相 除 后 的 结果 为 43， 应 用 ceil(4.3) 
后 的 结果 为 5。 

@ ”iconv_strlen: 计算 文章 长 度 。 

上 日 iconv_substr: 对 文章 进行 截取 。 


技巧 : 
使 用 iconv_substrO0 函 数 对 中 文字 符 串 进行 截取 ， 可 以 避免 出 现 乱 码 的 现象 。 


3.7.7 ”弹出 窗口 修改 日 记 


单 击 “查看 日 记 ” 中 的 “阅读 全 文 ” 超 链接 ， 将 弹出 修改 日 记 的 页 面 。 该 页 面 显示 
日 记 主题 、 心 情 、 日 记分 类 、 日 记 发 表 的 时 间 及 日 记 内 容 。 当 用 户 对 日 记 修改 完成 后 ， 单 
击 “ 编 辑 ” 按 钮 ， 即 可 实现 日 记 信息 的 更 改 ， 并 且 在 关闭 弹出 窗口 的 瞬间 ， 日 记 信 息 的 显 
示 页 面 也 会 自动 进行 刷新 。 日 记 修改 处 理 页 代码 如 下 所 示 : 

代码 位 置 ， 配 套 资源 \mr\03\ updiary.php 


01 <?php 
02 include once("conn/conn.php"); // 包 含 数据 库 连 接 文 件 


“2s 
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03 $id=$ GET["id"]; // 获 取 超 链 接 传递 的 ID 值 


04 $sql=mysql query("select* from tb jour where id=".$id."); /执行 查询 语句 ， 以 传递 的 | 
值 为 条 件 ! 

05 $info=mysql fetch_array($sql); 

06 iflisset($ POST["Submit"]){ // 判 断 提交 按钮 是 否 为 真 

07 $wzzt-trim($_ POST['wzzt]): // 获 取 表 单 提交 的 更 新 数据 

08 $sj=$_POST['time']: 

09 $lb=$ POST[TH]: 

10 $wznr-$ POST['wznr]; | 


11 $sql="update tb jour set wzzt=".$wzzt.",time=".$sj.",tjfl=".$lb.",wznr=".$wznr." where | 
id-w.$_ POST[id] | 


12 这 mysql query($sql,$conn)){ /执行 更 新 语句 
13 echo "<script>alert( 日 记 更 改 成 功 ! "):window.openerlocation reload0:window:.close(:</script>"; 
14 }else{ | 
15 echo "<script>alert( 日 记 更 改 失败 ! "):history.back0;</script>"; | 
16 } | 
17 exit; | 
nh | 
19 > 


说 明 : | 
编辑 用 户 日 记 页 面 ， 实 现 用 户 关 闭 弹 出 窗口 前 ， 自 动 刷新 父 窗 口 ， 实 现 语句 如 下 : “| 


window.opener.location.reload(); | 

上 述 代码 的 实现 原理 是 在 用 window:.close0 语 名 关闭 弹出 窗口 前 ,调用 父 窗口 的 reload0 
方法 实现 父 窗口 的 刷新 。 | 
3.7.8 查询 日 记 的 实现 过 程 
在 查询 日 记 页 面 中 可 以 按 日 记 主题 、 日 记 内 容 以 及 日 记分 类 3 种 方式 进行 模糊 查找 。 | 

用 户 首先 选择 查询 方式 , 然后 添加 要 查找 的 关键 字 , 最 后 单 击 “ 查 询 ”按钮 即 可 完成 查找 。| 
查询 页 面 的 运行 结果 如 图 3.30 所 示 。 


查询 日 记 


请 选择 查找 方式 内 容 ”> 幸福 [查询 ] 

文章 主题 : 走 进 你 生命 中 的 三 个 人 分 类 : 请 选择 

肯 离开 ; 如 果 你 还 爱 他 ， 你 应 该 会 希望 他 过 得 幸福 快乐 ， 希 望 他 跟 真 正 爱 的 人 在 一 起 ， 绝 不 会 阻 

止 ， 你 要 是 阻止 他 得 到 真正 的 幸福 ， 就 表示 你 已 经 不 爱 他 了 ， 而 如 果 你 不 爱 他 ， 你 又 有 什么 资格 

指责 他 交心 呢 ? 爱 | 
| 查看 全 文 | | 

文章 主题: 幸福 的 明 间 ， 你 拥有 几 个 ? 分 类 : 心情 

{1 幸福 就 是 早上 醒 末 ,看 到 一 抹 阳 光 恰好 藻 到 枕 边 。 可 以 不 用 龟 着 起 床 ， 往 在 被 宫 里 听 着 妈妈 在 

厨房 里 轻 手轻 脚 的 忙碌 ， 不 一 会 儿 荷 包 蛋 的 香味 水 漫 了 整个 房间 。 {2. 幸福 就 是 穿着 白色 的 棉布 

长 禄 走 在 华灯 初 上 的 | 
| 查看 全 文 | 


图 3.30 查询 日 记 页 面 的 运行 结果 


“M3s 


mR 人 Pep 项目 委 仙 分析 
Km 
查询 日 记 的 实现 过 程 如 下 。 


(1) 建立 表单 ， 查 询 日 记 的 表单 元 素 如 表 3.16 所 示 。 
表 3.16 查询 日 记 的 表单 元 素 


重要 属性 


含义 


method="post"actio 
(this)" 


=""onsubmit="returnchkinput_search 


表单 


size="15" 
<select name="type" > 
<option value=""> 请 选择 </option> 


<option value="1"> 主 题 </option> 
select 


e 
Pp <option value="2"> 内 容 </option> 


<option value="3"> 分 类 </option> 
</select> 
value=" 查 询 " id="Submit" 


(2) 应 用 


代码 位 置 ， 配 套 资源 \mr\03\querydiary.php 


查询 关键 字 


查询 方式 


“查询 ”按钮 


| JavaScript 脚本 自 定义 chkinput_search0) 函 数 ， 实 现 对 表单 提交 的 信息 进行 
| 验证， 代码 如 下 : 


01 <script language="javascript"> 

[12 function chkinput_search(form){ 

03 if(form.type.value—""){ // 验 证 查询 条 件 是 否 为 空 
04 alert(' 请 选择 查询 条 件 ! "); 

05 form.type.focus0; 

06 return(false): // 返 回 结果 
07 } 

08 if(form keyword.value—""){ 

09 alert(' 请 输入 查询 关键 字 ! 7); 

10 form.keyword.focus0; 

11 return(false); 

12 } 

13 return(true): 

14 

15 ) 

16 </script> 


(3) 将 表单 信息 提交 到 数据 处 理 页 ， 连 接 数 据 库 文件 ， 接 收 表单 信息 ， 然 后 用 
mysql_ query0O 函 数 向 服务 器 发 送 SQL 语句 , 检索 与 查询 关键 字 相 匹配 的 信息 资源 , 代码 如 下 : 


代码 位 置 : 配套 资源 \mr\03\querydiary.php 


01 <?php 

02 include_once("conn/conn.php"); 
03 if($_POST["Submit"]!=""){ 

04 $type=$_POST["type"]: 

05 $keyword=$_ POST["keyword"]: 
06 if($type—1){ 
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/连接 数据 库 

// 浏 断 提 交 按 钮 是 否 为 空 

/获取 提交 的 数据 

/获取 提交 的 关键 字 

/根据 指定 的 类 型 ， 执 行 模糊 查询 
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07 $sql-mysql_query("select * from tb _jour where wzzt like '%$keyword%' order by | 
id desc limit 2"): | 
08 }elseif($type—2){ | 
09 $sql=mysql_query("select * from tb jour where wznr like '%$keyword%' orderby | 
id desc limit 2"); | 侠 
10 }elseif($type—3){ | 
11 S$sql=mysql query("select * from tb jour where rjfl like '%$keyword%' order by id | 
desc limit 2"); 
12 j 
13 S$info=mysql_ fetch_array($sq]l); // 获 取 查 询 结 果 
14 这 $info 一 false){ 
15 echo "<br><br><div align=center> 对 不 起 , 没有 查找 到 您 要 查找 的 内 容 !</div>"; 
16 }else{ 
1 dof 
18 > 


(4) 用 do...while 循环 语句 输出 与 查询 关键 字 相 匹配 的 信息 资源 ， 并 用 str_ireplace() 
函数 对 查询 关键 字 进 行 描 红 ， 代 码 如 下 : 
代码 位 置 ， 配套 资源 \mr\03\querydiary.php 


01 <?php 

02 这 $info 一 false){ 

03 echo "<br><br><div align=center> 对 不 起 ， 没 有 查找 到 您 要 查找 的 内 容 ! </div>"; 

04 }else{ 

05 dof 

06 ?> 

07 <table width="515" border="0" cellpadding="0" cellspacing="0"> 

08 <tr> 

09 <td width="405"> 文 章 主题 : 

10 <?php echo str_ireplace(Skeyword,"<font color='#FF0000'>".Skeyword."</font>", Sinfo 
['"Wwzzt'"]);?> </td> 

11 

12 <td width="110"> 分 类 : 

13 <?php echo str_ireplace(Skeyword,"<font color='#FF0000'>".Skeyword."</font>", Sinfo 
['rjf"]);?> </td> 

14 </tr> 

15 <t> 

16 <td colspan="2"> 

17 <?php echo str_ireplace(Skeyword,"<font color='#FF0000'>".Skeyword."</font>", Sinfo 
['wznr']);?> </td> 

18 </t> 

ly </table> 

20 <2php 

21 }while($info=mysql _fetch _array($sql)): 

22 } 

23 

24 > 


“iss 


/ | 
入 
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3.7.9 应 用 JavaScript 实现 批量 删除 


当 用 户 登录 后 ， 单 击 “ 我 的 日 记 ”/“ 删 除 日 记 ” 超 链接 ， 可 进入 到 删除 日 记 页 
| “appenddiary.php)。 为 了 方便 用 户 执行 删除 操作 ,本 项 目 通 过 复 选 框 的 全 选 、 反 选 和 不 选 ， 
| 来 实现 网 络 日 记 的 批量 删除 。 删 除 日 记 页 面 的 运行 结果 如 图 3.31 所 示 。 


删除 日 记 
25 爱 的 感言 2011-04-26 11:42:36 
加 | 如 幸福 的 瞬间 ， 你 拥有 几 个 ? 2011-04-26 11:47:07 
回 | 2 走 进 你 生命 中 的 三 个 人 2011-04-26 15:00:00 
全 连 。 - 及 迁 。。 不 法 。- 竹 除 。 


图 3.31 批量 删除 日 记 
删除 日 记 的 实现 过 程 如 下 。 
(1) 创建 js 文件 夹 , 编写 regjs 脚本 文件 。 在 regjs 中 ， 编 写 自 定义 函数 ， 实 现 全 选 、 
反选 和 不 选 功能 。regjs 文件 的 关键 代码 如 下 : 
代码 位 置 ， 配套 资源 \mr\03\js\reg.js 


| 01 function uncheckAll(form!l,status) { // 不 选 

| 02 var elements = forml.getElementsByTagName(input): /获取 input 标签 

| 03 for(var i=0; i<elements length: i++){ /根据 标签 的 长 度 执行 循环 
| 04 if(elements[i].type =— 'checkbox') { 1/ 判断 对 象 中 元 素 的 类 型 
| 05 if(elements[i].checked==true){ // 判 断 当 checked 的 值 为 tue 时 
| 06 elements[i].checked=false: /为 checked 赋值 为 false 
| 07 } 

| 08 F 

| 09 } 

| LO 

| 11 function checkAll(forml,status){ /全 选 

| 12 Var elements = forml.getElementsByTagName(input); 

| 13 for(var i=0: i<elements length: i++){ 

| 14 if(elements[i].type — 'checkbox'’) { 

| 1 if(elements[i].checked=—false){ 

| 16 elements[i].checked=true: 

| 17 } 

| 18 

| 19 } 

| 20000 

| 21 function switchAll(form!l,status) { /反选 

| 22 var elements = forml.getElementsByTagName(input)); 

| 23 for(var i=0; i<elements.length; i++){ 

| 24 if(elements[i].type — 'checkbox'){ 

| 25 if(elements[i].checked—true){ 

| 26 elements[i].checked=false: 

| 27 }else 这 elements[i].checked 一 false){ 

| 28 elements[i].checked=true: 
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29 
30 
3 
3 


} 


(2) 创建 deldiary.php 页 面 ， 输 出 日 记 信息 ， 并 添加 图 像 按钮 ， 通 过 onClick 事件 调 
用 JavaScript 自 定义 函数 实现 全 选 、 反 选 、 不 选 和 删除 的 功能 ， 其 关键 代码 如 下 : 
代码 位 置 ， 配套 资源 \mr\03\deldiary.php 


01 
02 
03 


25 


<script language="javascript" src="js/reg.js"></script> 
<form method="post" name="form1" id="form1" action="index_ok.php"> 


<?php 

include_once("conn/conn.php"); // 包 含 数据 库 连 接 文件 
$result=mysql_query("select * from tb jour where id limit 5",$conn); /执行 查询 语句 
while($myrow=mysql fetch_array($resulb){ /循环 输出 查询 结果 
> 

<tr> 


<td width="62" align="center"><!-- 创 建 复 选 框 --> 


<input type="checkbox" name="conn id[]" value="<?php echo $myrow['id']:?>" id="conn | 


<td width="30" ><?php echo $myrow['id']:?> </td> 
<td width="267" ><?php echo $myrow['wzzt]:?> </td> 
<td width="160" ><?php echo $myrow['time'];?></div></td> 
</tr> 
<?php 
} 
了 > 
<tr> 


<img src="images/bg_19-20.jpg" onclick="checkAl(form1,status)" width="62" height="25"> 
<img stc="images/bg_14-14.jpe" onclick="switchAll(forml,status)" width="62" height="25"> 
<img src="images/bg_07-08.jpg" onclick="uncheckAllforml,status)"” width="62" height="25"> 
<input type="image" name="imageField" src="images/bg_14.jpg" /></td> 

</tr> 

</form> 


据 表 中 指定 的 数据 ， 其 代码 如 下 : 
代码 位 置 ， 配套 资源 \mr\03\deldiary_1.php 


01 
02 
03 


$conn); 


<2php 
include_once("conn/conn.php"); // 连 接 数 据 库 
if($_POST['conn id"]!=""){ /判断 POST 方法 中 传递 的 数据 是 否 为 空 


for($i=0;$i<count($_POST['conn id"]);$i++){// 使 用 for 循环 读 取 数 据 中 的 元 素 
Sresult=mysql_query("delete from tb jour where id=".$ POST['conn id'][$i].""， 
// 执 行 删除 操作 
} 
if($result){ 
echo "<script>alert( 删 除 成 功 !"); window.location.href='index.php?link=".urlencode(" 添 
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<td colspan-"sralign-'eenter'><l- 通 过 onClick 事件 调用 自 定义 函数 , 执行 相应 的 操作 -> | 


(3) 创建 deldiary_1.php 文件 ， 根 据 复 选 框 中 传递 的 ID 值 ， 执 行 删除 操作 ， 删 除数 


(了 ap 项 目 业 全 分 析 


加 日 记 ").":</script>"; 


09 上 

10 jelsef 

11 echo "<script>alert(' 请 选择 要 删除 的 内 容 !"); </script>"; 
oa 

Bs 


3.8 管理 日 记 本 


”3.8.1 管理 日 记 本 概述 


为 了 保护 用 户 日 记 及 财务 等 记录 的 安全 ， 用 户 可 以 通过 “管理 日 记 本 ”/“ 修 改 密码 ”功能 


定期 对 密码 进行 修改 ， 这 样 就 大 大 提高 了 网 络 日 记 的 安全 性 。 修 改 密码 的 页 面 如 图 3.32 所 示 。 


确认 新 密码 :seeeeeee 
[重要 | 


图 3.32 修改 密码 界面 


| 3.8.2 MD5 加 密 技术 


MDS5 是 在 Web 应 用 程序 中 最 常用 的 密码 加 密 算法 之 一 ， 它 和 crypt0 函 数 一 样 也 是 单 


| 项 加 密 的 。MD5 广泛 用 于 数据 加 密 技术 ， 在 很 多 网 站 中 ， 用 户 的 密码 是 以 MD5 值 的 方式 
| 保存 的 ， 用 户 登 录 时 ， 程 序 员 把 用 户 输入 的 密码 计算 成 MD5 值 ， 然 后 和 数据 库 中 保存 的 


MDS5 值 进行 比较 , 而 程序 本 身 并 不 知道 用 户 密码 的 真实 值 ,从 而 起 到 保护 用 户 数据 的 作用 。 
md50 函 数 用 来 计算 字符 串 的 MDS 混合 值 。 其 语法 如 下 : 
string md5(string str); 
梦幻 网 络 日 记 修改 密码 功能 即 采 用 md50 函 数 获取 字符 串 加 密 后 的 值 。 加 密 用 户 密码 
的 部 分 代码 如 下 : 


01 <?php 

02 Soldpwd=md5($_POST[jmm'); // 使 用 md50 对 输入 的 原 密 码 进行 加 密 
03 Snew=md5($ POST['xmm']); // 使 用 md50 对 输入 的 新 密码 进行 加 密 
04 -echo $oldpwd; // 返 回 加 密 后 的 值 

05 echo $new: // 返 回 加 密 后 的 值 

06 > 
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3.8.3 ”修改 密码 的 实现 过 程 


用 户 在 表单 中 输入 用 户 名 、 原 密码 、 新 设 定 的 密码 及 确认 新 密码 后 ， 单 击 “ 确 认 ” 按 负 | 
就 可 以 将 表单 中 的 信息 提交 到 chkquerymotifphp 文件 中 对 密码 进行 更 改 ， 在 该 文件 中 ,首先 | 
判断 用 户 输入 的 用 户 名 及 原 密码 是 否 正确 ， 如 果 提 交 的 用 户 名 及 密码 正确 ， 则 使 用 update 语 | 
名 对 用 户 登录 密码 进行 更 改 ， 反 之 ， 则 给 出 原 密码 错误 的 提示 信息 ， 其 关键 代码 如 下 : 

代码 位 置 ， 配套 资源 \mr\03\chkquerymotif.php 


01 <?php 

02 include once("conn/conn.php"); // 包 含 数据 库 文件 

03 _ Suer=trim($ POST['userne']); // 使 用 tim0 函 数 去 除 掉 提交 的 用 户 名 空格 

04 $oldpwd=mds($_ POST[Jmnm']); /使 用 md50 对 输入 的 原 密码 进行 加 密 

05 $new=md5($ POST[xmm']): // 对 新 密码 进行 加 密 

06 $qnew=mds($_POST[qxmm'T): ! 

07 $sql="selectiduserfrom tb reg where user=".$uer." andpassword=".$oldpwd."; /使 用 select | 
语句 查询 用 户 名 及 密码 | 

08 $result=mysql_query($sql,$conn); 

09 ”S$info=mysql fetch object($resulb; 。“”// 获 取 查 询 结 果 集 


10 iflis object($info)){ // 应 用 is_object0 函 数 检测 查询 的 结果 集 是 否 为 对 象 | 
11 if(mysql_query("update tb_reg set password=".md5($new).", | 
12 ”qrpass=".md5($qnew)." where user=".$uer.")){ // 使 用 update 语句 更 新 密码 

13 echo "<script>alert(' 密 人 码 更 改 成 功 !");window.location.href='index.php';</script>"; 

14 er 

15 echo "<script>alert( 密 码 更 改 失败 !):history .backO:</script>"; 

16 } 

17 }else{ 

18 echo "<script>alert( 原 密码 输入 有 误 !):history.backO;</script>"; 

Foe 

20 2 


3.9 项 目 发 布 


1. 搭建 PHP 运行 环境 


由 于 笔者 在 开发 项 目 时 应 用 AppServ 集成 化 安装 包 搭 建 的 PHP 运行 环境 ， 所 以 建议 
读者 也 应 用 AppServ 来 搭建 PHP 运行 环境 。 这 样 可 以 确保 项 目 正 常 运行 。 | 


2. 具体 项 目 发 布 方法 


(1) 将 程序 文件 夹 03 复制 到 AppServ 安装 后 的 www 文件 夹 下 。 | 

(2) 在 03 文件 夹 下 , 定位 到 data 文件 夹 , 复制 该 文件 夹 下 的 数据 库 文件 夹 ab diary， | 
将 其 存储 于 本 机 AppSerwMySQLvdata 文件 夹 下 ， 并 且 去 掉 数 据 库 文件 的 只 读 属性 。 | 

(3) 最 后 确定 本 机 设置 的 MySQL 数据 库 密码 与 程序 中 设置 的 默认 密码 是 否 相同 ( 程 | 
序 中 设置 的 数据 库 用 户 名 是 root， 密 码 是 111)。 
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本 章 小 结 
到 | 在 梦幻 网 络 日 记 项 目 中 ， 应 用 到 了 很 多 关键 技术 ， 这 些 技术 在 开发 过 程 中 都 是 比较 常 
用 的 。 下 面 将 简略 地 介绍 一 下 这 些 关键 技术 在 实际 中 的 用 途 ， 希 望 对 读者 的 二 次 开发 有 所 


启示 。 

(1) 二 级 导航 菜单 设计 常 被 用 在 网 站 的 前 台 ， 可 以 使 导航 看 起 来 层次 分 明 ， 本 项 目 
采用 右 弹 出 二 级 导航 菜单 ， 读 者 可 以 修改 相关 参数 ， 做 成 下 弹 式 二 级 导航 菜单 。 

(2) 本 项 目 网 页 曾 钟 采用 的 是 Ajax 无 刷新 验证 ， 在 实际 开发 中 ，Ajax 还 可 以 实现 提 
交 表 单数 据 的 无 刷新 验证 、 用 户 名 是 否 被 占用 无 刷新 验证 及 无 刷新 的 下 拉 列 表 。 

(3) 本 项 目的 日 记 删 除 页 应 用 JavaScript 实现 复 选 框 的 全 选 、 反 选 和 不 选 ， 从 而 实现 
| 批量 删除 。 在 实际 开发 中 ， 还 可 以 应 用 JavaScript 实现 复 选 框 的 全 选 、 反 选 和 不 选 来 实现 
| 批量 添加 和 修改 。 
| (4) 本 项 目的 六 铃 试听 和 闸 铃 播放 功能 ， 还 可 以 应 用 到 为 网 页 添加 背景 音乐 的 功能 
| 中 ， 适 合 于 博客 或 者 微 博 类 网 站 的 开发 应 用 。 

(5) 本 项 目 中 的 查询 关键 字 描 红 技术 使 用 更 加 广泛 ， 可 以 应 用 到 论坛 、 博 客 等 网 站 
| 中 。 如 果 读 者 感 兴趣 ， 还 可 以 增加 统计 查询 用 时 、 查 询 结果 数 的 功能 。 
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企业 网 站 系统 


( PHP+MySQL 实现 ) 
合 0 自学 视频 、 源 程序 : 配套 资源 \mm4\ 


作为 20 世纪 人 类 创造 的 伟大 奇迹 ，lnternet 已 经 展现 出 巨大 的 潜力 ， 已 经 
渗透 到 我 们 生活 的 方方面面 。 而 首当其冲 的 就 是 利用 Internet 实现 商业 运作 。 
未 来 的 企业 将 通过 Internet 连 在 一 起 ,构成 世界 范围 的 供应 链 、 物 流体 系 ， 产 、 
供 、 销 等 环节 都 将 通过 Internet 进行 。Internet 向 众 商家 展现 了 一 个 美好 的 前 
景 和 机 遇 ， 使 许多 企业 前 发 了 向 Internet 进军 的 欲望 。 

企业 网 站 系统 是 针对 中 小 企业 开发 设计 的 一 个 项 目 ， 上 有 具备 中 小 企业 所 需 的 
基本 功能 ， 是 开发 中 小 企业 网 站 的 一 个 很 好 的 模板 。 

通过 阅读 本 章 ， 读 者 可 以 学 到 : 


项 目 设计 思路 
数据 库 设 计 

首页 页 面 设计 

最 新 活动 模块 设计 
产品 中 心 模块 设计 
客户 反馈 模块 设计 

后 台 主 页 设计 

软件 产品 管理 模块 设计 


和 总理 有 划 有理 理 理 吾 吾 


| 人 ED 项 目 娄 全 分 析 


4.1 项 目 设计 思路 


4.1.1 功能 阅 述 


wi 系统 根据 中 小 企业 对 企业 网 站 的 需求 ， 实 现 了 产品 展示 、 客 户 反馈、 技术 支 
| 持 、 硬 件 产品 管理 、 党 见 问题 管理 和 说 明 书 管理 等 相关 功能 ， 并 将 网 站 分 为 前 台 和 后 台 丙 
| 部分， 前 全 为 普通 用 户 浏览 区 ， 后 台 为 网 站 管理 员 对 网 站 信息 进行 管理 ， 以 便 对 网 站 数据 

| 进行 及 时 更 新 和 维护 。 

| 4.1.2 系统 预览 

企业 网 站 系统 由 多 个 页 面 组 成 ， 下 面 列 出 几 个 典型 页 面 ， 其 他 页 面 请 参见 配套 资源 中 

的 源 程序 。 

企业 网 站 系统 主页 面 的 运行 效果 如 图 41 所 示 。 


Dy rensorr co 


图 4.1 企业 网 站 系统 主页 面 
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公司 软件 产品 分 类 页 面 的 运行 结果 如 图 4.2 所 示 。 


日 企业 网 站 日 视频 类 


日 语音 卡 类 日 管理 类 

日 编程 问 典 日 过 用 工具 类 
页 次 : 1/1 页 记录 :6 条 

日 ”网络 类 

日 ”录像 设 备 

日 ”语音 类 


be 主要 内 容 有 : 
(1 ) 帮助 黎 广 册 你: 


《6 ) 适合 中 国法 律 ， 一旦 发 和 争执， 用户 有 保障 ,企业 注册 更 安心 
中 国标 识 ， 全 球 开放 ， 挫 和 神 在 手 ， 把 握 商 机 ? 


2 
IE 
我 公司 为 您 提供 全 面 的 虚拟 主机 服务 
和 生生。 和 tags 村、 亲 4Ema 
1 
《 3 性 能 上 下， 志 冰 强大 
| 


本 公司 提供 多 种 邮局 产品 ( 企业 邮局 ，YIF 邮 局 ) ,可 满足 不 同 层次 企业 用 户 对 邮件 系统 不 同 的 
需要 。 另 外 ， 本 公司 邮局 系统 预 留 丰 富 应 用 接口 ， 格 不 断 对 产品 的 功能 进行 升级 ， 同 时 采用 分 布 式 
体系 结构 ， 具 有 海量 、 高 效 、 安 全 、 可 靠 等 特点 ,是 企业 电子 商务 信息 交 扫 的 理想 平台 。 


漠 细 -| 


图 4.2 公司 软件 产品 分 类 页 面 运行 结果 
常见 问题 页 面 的 运行 效果 如 图 4.3 所 示 。 
La 


Q@: 。 用 户 问题 有 问 必 答 


用 。 加 果 你 在 使 用 由 “吉林 省 明日 科技 有 限 公司 ”开发 的 程序 或 网 站 时 ， 如 过 到 什么 问题 不 能 
解决 ， 欢 迎 您 在 本 站 留言 ， 或 直接 扰 打 我 公司 的 客户 服务 热 贱 : 0431-84978961 84978962 


Q: 。 应 用 程序 如 何 运行 ? 
不 。 吉林 省 明日 科技 有 限 公司 开发 的 所 有 应 用 程序 均 配 置 一 个 程序 使 用 说 明 书 ， 用户 可 参考 相 
应 程序 的 使 用 说 明 书 运行 应 用 程序 。 


Q: 。 同 站 Is 的 配置 

去: ”建立 虚拟 目录 或 站 点 ， 然 后 运行 网 站 。 
Q: 。 员工 进取 

和: 。 请 辞 读 阅 《 孙 悟空 是 个 好 员工 》 一 书 
Q: 。 附加 涩 据 库 


入: ”应 用 程序 或 网 站 在 正常 运行 前 ,需要 进行 数据 库 配 置 。( 1 ) S9L Server 数 据 库 ,请 附加 数 
据 库 。( 2 ) Access 数 据 库 ,请 去 除数 据 库 的 只 读 属 性 。( 3 ) tyS9L 激 据 库 ， 请 格 数据 库 持 贝 到 
MySq1 数 据 | data 文 件 夹 下 。 


页 次 1/1 页 记录 : 5 条 


图 43 软件 常见 问题 页 面 运行 结果 
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添加 软件 产品 页 面 的 运行 结果 如 图 4.4 所 示 。 


添加 软件 产品 
软件 名 称 [ie 入 得 梧 笑 
软件 类别 编程 梧 身 “可 
文件 大 小 [Ez 注意 : 请 给 入 文件 单位 (如 : KB、MB、 6) | 
软件 包装 图 Foements md SettinesWinin LN | 注意 : 支持 .gf 和 .gif 格式 的 图 片 
上 传 软件 [Eeements and SettinesWdnin 且 计 阁 国 下 | 广 意 : 上 传 欢 件 不 能 大 于 50MB 


软件 文档 [C:\Documents and Settings\Adnin | 浏览 | 注意 : 上 传 文档 为 .html 格式 


! 
| 

| [ 

! 《yisual CH 编程 全 能 词典 》 内 容 包含 Visual C+ 编程 入 门 技能 学 习 与 训 绕 及 全 到 
| | 程 技术 支持 ，25. 5 小 时 开发 录像 ，11 个 行业 项 目 开发 ，10 个 行业 项 目 源码 , 5.5 

! 产品 介绍 个 多 6 开发 内 容 ( 技术 、 实 例 、 技 巧 、 模 块 、 项 目 、 界 面 、 图 书 等 海量 资源 ) ， 
HT 辅助 词典 、 工 具 集 、 百 宝箱 ) ，12 次 有 限 升 
| 务 . | 


回 


是 | 
图 4.4 添加 软件 产品 页 面 运行 结果 
4.1.3 ”功能 结构 


根据 功能 分 析 ， 创 建 出 企业 网 站 系统 的 功能 结构 图 。 一 个 完善 的 功能 结构 图 对 网 站 的 
整体 开发 具有 指导 意义 ， 它 能 让 项 目 开 发 的 目标 更 加 明确 ， 流 程 更 加 清晰 。 企 业 网 站 系统 
的 功能 结构 如 图 4.5 所 示 。 


企业 网 站 系统 


状 窑 举 
由 到 


En: 


由 囊 证 二 瑟 过 
妾 
典 囊 注 
崩 囊 交互 六 于 


内 吕 


OD 


| 图 4.5 企业 网 站 系统 功能 结构 图 
4.1.4 文件 组 织 结构 


企业 网 站 系统 中 使 用 的 根 目录 文件 夹 是 04， 其 中 包括 的 文件 架构 如 图 4.6 所 示 。 
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区 = 
田 情 adnin 一 一 一 一 一 一 一 一 一 一 后 台 管 理 文件 
田 岂 ”agant 一 一 一 一 一 一 一 一 一 一 用 于 存 铸 说 明 书 下 载 文 件 
日 - 鲍 Com 
团 conn php 数据 库 连 接 文件 

ca= ess 用 于 存储 CSS 样 式 文件 | 7 
日 - 岛 Data ! 

由 -全 。db_ningri 一 一 一 一 一 一 一 一 数据库 文 件 | 
局 Hash 一 一 一 一 一 一 一 一 一 一 flash 交 件 | 
局 hxdrare 一 一 一 一 一 一 一 一 一 用 于 存储 硬件 下 载 文件 
田 生 inaees 一 一 一 一 一 一 一 一 一 图 片 文件 ! 
自信 js 一 J 文件 | 
向 襄 soft 一 一 用 于 存 铺 软 件 下 载 文件 | 
局 pload 一 一 一 一 一 一 一 一 一 一 网 站 上 传 的 图 片 文件 

国 : e: 添加 留言 页 面 

a 运行 网 站 自动 弹出 窗口 文件 

加 一 公 省 洋 细 信 息 页 

国 ”lresolvent.php 一 一 一 一 一 一 软件 产品 分 类 显示 页 

团 botton. php 网 站 尾 文件 

团 check_guestboard php 添加 留言 信息 处 理 页 


图 4.6 企业 网 站 系统 的 文件 架构 图 


4.2 数据 库 设 计 


应 用 PHP 开发 中 小 企业 的 网 站 ， 数 据 库 的 最 佳 选择 就 是 MySQL。MySQL 是 一 个 关 | 
系数 据 库 管理 系统 ， 把 数据 存储 在 表格 中 ， 使 用 标准 的 结构 化 查询 语言 一 SQL 访问 数据 | 
库 。MySQL 是 完全 免费 的 ， 可 以 在 网 上 任意 下 载 ， 还 可 以 查看 源 文 件 ， 进 行 必要 的 修改 。| 

MySQL 服务 器 的 功能 齐全 、 运 行 速度 极 快 ， 十 分 可 靠 ， 有 很 好 的 安全 性 。 它 在 客户 、| 
服务 器 或 嵌入 系统 中 使 用 ， 是 一 个 客户 机 /服务 器 系统 ， 能 够 支持 多 线程 ,支持 多 个 不 同 的 
客户 程序 和 管理 工具 。 | 

MySQL 还 具备 良好 的 可 视 化 图 形 管理 工具 ， 能 够 快速 、 简 捷 地 完成 数据 库 、 数 据 表 | 
的 创建 操作 。 与 PHP 搭档 使 用 ， 堪 称 是 “黄金 组 合 ”。 | 


4.2.1 数据 库 设计 结构 


数据 库 设 计 是 一 个 非常 关键 的 环节 ， 合 理 设计 网 站 的 数据 库 ， 是 网 站 高 效 、 稳 定 运行 | 
的 关键 。 企 业 网 站 系统 数据 库 (db _mingri) 包含 的 数据 表 如 图 4.7 所 示 。 | 


胃 服务 器 : localhost ， 轧 数据 库 : db_mingri 

表 择 作 记录 数 ! ”类 型 整理 说 明 
admin 国宝 加 革 国 Xx 1 MYISAM gb2312_chinese_cl 管理 几 革 所 去 
affiche 图 加 回 关 国 X 4 MyYISAM gb2312_chinese_cl 如 新 信息 
guestboard 国 苛 回 并 性 X 3 MYISAM gb2312_chinese_ci RE 
hardware 图 匣 回 基 国 1 MyISAM gb2312 chinese_ci 硬件 产品 洁 和 去 
link 国 认 加 基 国 X 4 MySAM gb2312 chinese ci 明镜 党 信息 友 
mend 国富 加 基 国 Xx 1 MySAM gb2312_chinese_ci 产品 下 埋 半 忆 表 
news 国语 加 闫 国 X 3 MySAM gb2312 chinese ci es 
question 加 本 加 基 便 XX 5 MySAM gb2312_chinese_cl 区 从 风 问题 家 
resolvent 加 只 四 六 力 X 6 MyISAM gb2312_chinese_ci 斩 HR# 雪 而 
soft 国 写 加 基 是 xX 5 MySAM gb2312_chinese_cl 产品 信息 去 
ssort 国 上 二 回国 Xx 6 MyISAM gb2312_chinese_ci 元 人 座 朋 和 下载 半生 

图 4.7 企业 网 站 系统 数据 库 包 含 的 数据 表 


“5 a 


a 人 Pitp 项 目 娄 们 分 析 
| RS 
| 4.2.2 数据 表 设计 结构 


”下 面 对 企业 网 站 系统 中 主要 的 数据 表 设 计 以 表格 的 形式 列 出 ， 其 余数 据 表 设 计 请 参见 
| 数据 库 文件 。 


管理 员 信息 表 主 要 用 于 存储 管理 员 的 登录 用 户 名 及 密码 ， 数 据 表 字段 设计 如 表 4.1 所 示 。 
表 4.1 管理 员 信息 表 (admin) 设计 


说 
id i auto increment 信息 id 

图 书 类 别 
图 书 语言 


明 


2. 最 新 活动 信息 表 (affiche ) 
最 新 活动 信息 表 主 要 用 于 存储 活动 信息 ， 数 据 表 字段 设计 如 表 4.2 所 示 。 
表 4.2 最 新 活动 信息 表 (affiche) 设计 
字 段 | 类 型 | 额外 | 说 了 明 
| nt | auto increment | 信息 这 
| | 活动 标题 
aime | dateime | 发 布 时 间 
content | medivmext | | 活动 内 容 
3. 留言 信息 表 ( guestboard ) 
留言 信息 表 主 要 用 于 存储 用 户 留 言 信息 ， 数 据 表 字段 设计 如 表 4.3 所 示 。 
表 4.3 留言 信息 表 (guestboard) 设计 


字段 类 型 说 了 明 

gid int 信息 id 
title Varchar 一 一 一 留言 标题 

guest Varchar 留言 人 
gtime date | 留言 时 间 
| content Varchar 留言 内 容 
| 2flag tinyint 是 否 回复 
| rtime date 回复 时 间 
| recontent mediumtext 回复 内 容 
gshow tinyint 是 否 显示 


4. 硬件 产品 信息 表 (hardware ) 
硬件 产品 信息 表 主 要 用 于 存储 硬件 产品 信息 ， 数 据 表 字段 设计 如 表 4.4 所 示 。 
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说 明 


信息 id 


硬件 名 称 


硬件 类 别 
硬件 文档 


info 


5. 友情 链接 信息 表 (link ) 


友情 链接 信息 表 主要 用 于 存储 友情 链接 信息 ， 数 据 表 字段 设计 如 表 4.5 所 示 。 


表 4.5 友情 链接 信息 表 (link) 设计 


字 段 说 明 
lid i 信息 id 
name I 链接 网 站 名 称 
ltime | 发 布 日 期 
ul | vr | | 链接 网 站 地 址 
6.， 新 闻 信息 表 (news ) 
新 闻 信息 表 主 要 用 于 存储 新 闻 信息 ， 数 据 表 字段 设计 如 表 4.6 所 示 。 
表 4.6 新 闻 信 息 表 (news) 设计 
字 段 类 型 额 外 说 阴 
nid int | auto increment | 信息 这 
title Varchar | | 新 闻 标 题 
ntime datetime | | 发 布 日 期 
content mediumtext | | 新 闻 内 容 


4.2.3 ”连接 数据 库 


硬件 说 明 


由 于 系统 大 部 分 页 面 都 需要 使 用 数据 库 ， 如 果 每 页 都 编写 相同 的 数据 库 连 接 代码 , 会 | 


显得 十 分 烦琐 ， 所 以 本 系统 将 数据 库 连 接 代码 单独 存 入 一 个 PHP 文件 conn.php 中 ， 


在 需 | 


要 与 数据 库 连 接 的 页 面 中 ， 使 用 包含 函数 包含 该 文件 即 可 ， 该 系统 实现 与 数据 库 连 接 的 代 | 


人 码 如 下 : 
01 <2php 
02 $link=mysql_connect("localhost","root","111"); /连接 数据 库 
03 mysql select db("db mingri",$link): // 连 接 数 据 库 
04 mysql_query("set names gb2312"); 

现 中 文 乱码 的 问题 
05 > 


:2 


服务 器 


// 对 数据 库 中 编码 格式 进行 转换 ,避免 出 


项 目 业 例 分 析 


43 首页 设计 
4.3.1 首页 页 面 概述 


运行 程序 ， 进 入 企业 网 站 系统 首页 ， 运 行 效果 如 图 4.8 所 示 。 首 页 左 侧 为 导航 区 域 和 
本 站 公告 区 域 ， 右 侧 为 产品 展示 区 域 。 当 用 户 单 击 左 侧 导 航 菜单 时 ， 右 侧 内 容 将 随 之 显示 
相应 的 内 容 。 


smnseorrzcn 


! 和 
! 1 有 限 和 本 服务 


| 得 全 能 记 关 》 内 容 把 二 Jews 扩 得 站 半 作 学 避 司 吕 言及 二条 持 
”Jr 省 | 2 个 行业 林 旧 所 罗 ， 8 个 本 6 


图 4.8 企业 网 站 系统 首页 运行 结果 
4.3.2 在 网 页 中 嵌入 Flash 动画 


本 网 站 在 页 面 上 方 嵌 入 了 Flash 动画 ， 既 起 到 了 软件 宣传 作用 ， 又 增加 了 页 面 的 动感 。 
在 HIML 页 面 中 嵌入 Flash 动画 应 用 的 是 Object 对 象 , 在 Dreamweaver 中 的 具体 操作 步 又 
如 下 : 
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第 生 章 企业 网 站 系统 (PHP+MNYSQL 实现 ) $9 | 


(1) 在 Dreamweaver 软件 中 ， 选 择 菜单 栏 中 的 “插入 ”/“ 媒 体 ”/Flash 命令 ， 如 | 
图 49 所 示 。 


Wa 
| 
| 
| 
| 
| 
| 


(2) 在 打开 的 窗口 中 选择 要 插入 的 Flash 文件 ， 即 可 完成 Flash 的 嵌入 操作 。 
(3) 将 Flash 文件 嵌入 到 页 面 中 后 ， 生 成 的 代码 如 下 : 


<object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="http://download. |! 
macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=7,0,19,0" width="553" height="145"> 

<param name="movie" value="flash/bookl.swf" /> 

<param name="quality" value="high" /> 

<embed src="flash/bookl.swf’ quality="high" pluginspage="http://www.macromedia.com/go/ | 
getflashplayer" type="application/x-shockwave-flash" width="553" height="145"></embed> 

</object> 


4.3.3 首页 页 面 实现 过 程 
首页 页 面 的 设计 效果 如 图 4.10 所 示 。 


图 4.10 首页 页 面 设计 效果 
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首页 页 面 的 实现 过 程 如 下 。 
(1) 通过 includeO 语 句 包含 网 站 头 文件 top.php， 在 头 文件 中 插入 Flash 动画 , 创建 网 
站 导航 的 超 链 接 。top.php 的 关键 代码 如 下 : 
代码 位 置 ， 配套 资源 \mr\04\top.php 
01 » <a href="http://www.mingribook.com'" target="” blank"” class="CategoryA"> 软 件 网 站 


</a>&nbsp; 

02 » <a href=" http://www.mingribook.com" target=" blank""” class="CategoryA"> 图 书 网 站 
</a>&nbsp; 

03 * <a href="#" class="CategoryA" onClick="this.style.behavior='"url(#default#homepage)'; 

04 this.sethomepage('htttp://www.mingribook.com'")"> 设 为 首页 </a>&nbsp; 

05 <a href="JavaScript:window.extemal.AddFavorite(http://www.mingribook.comy',' 企 业 网 站 系统 ')" 

06 class="CategoryA"> 加 入 收藏 </a>&nbsp; 

07 » <a href="mailto:mingrisoft(@mingrisoft.com" class="Cat " targef=”blank"> 联 系 我 们 </a> 


08 <object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" 

09 codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version 
= 0 

10 width="378" height="59"> 


11 <param name="movie" value="flash/In.swf" /> 
12 <param name="quality" value="high" /> 
13 <param name="wmode" value="transparent" /> 


14 <embed src="flash/In.swf" width="378" height="59" quality="high" 

15 pluginspage="http://www.macromedia.com/go/getflashplayer" 
type="application/x-shockwave-flash" 

16 wmode="transparent"></embed> 

17 </object> 


(2) 在 index.php 文件 中 , 编写 PHP 脚本 ， 通 过 文本 文件 统计 网 站 的 访问 量 ， 其 关键 
代码 如 下 : 
代码 位 置 ， 配 套 资源 \mr\04\index.php 


01 <?php 

02 session start(): // 初 始 化 session 变量 

03 include "Conn/conn php": // 载 入 数据 库 连接 文件 

04 ”S$tmp=(isset($_SESSION['times"]))?$_SESSION['times']:"0"; /根据 session 变量 值 设 置 变 
量 tmp 的 值 

05 $number=file get contents("./count.txt"): // 获 取 文 本 文件 中 存储 的 访问 量 

06 ifl!isset($ SESSION['times'"]) && $tmp 一 0){ // 屏 项 刷新 页 面 对 网 站 访问 量 
的 影响 

07 $number=$number+1l: // 将 获取 到 的 值 加 1 

08 file_ put_contents("./count.txt",$number): // 写 入 文件 

09 Stmp=1; // 重 新 为 变量 赋值 

10 $_SESSION['times']="1'; // 重 新 为 session 变量 赋值 

Ti 
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(3) 在 index.php 文件 中 ， 创 建 网 站 导航 菜单 级 联 菜单 。 通 过 鼠标 的 onMouseOut 和 
onMouseOver 事件 调用 JavaScript 脚 本 中 的 MM_ swapImsgRestore0 和 MM _swapImage() 方 法 
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人 


控制 导航 按钮 的 背景 ， 其 关键 代码 如 下 : 
代码 位 置 ， 配套 资源 \mr\04\index.php 


01 


it=3) 


X.STc=a[i+2];} 
22 
23 
24 
25 
26 
27 
28 
29 
30 
31 
32 
33 
34 


/定义 JavaScript 脚本 控制 导航 按钮 背景 
<script language="JavaScript" type="text/JavaScript"> 
<<!-- 
function MM _swapImgRestoreO { Wv3.0 
Var 1,x,a=document.MM sr; forG=0:a&&i<alength&&(x=a[i])&&x.oSrc:i++) X.STC=X.OSIC; 
} 
function MM_preloadImages() { //v3.0 
Var d=document; if(d.images){ if(!d MM _p) dMM p=new Array(); 
Var 1j=d.MM p.length,a=MM preloadImages.arguments; for(i=0; i<a.length; i++) 
if (ali].indexOf("#")!=0){ dMM pli]=new Image; dMM pli++].src=a[i];}} 
} 
function MM _ findObj(n, d) { //v4.01 
Var pD,LX; if(!d) d=document; if((p=n.indexOf("?"))>0&&parent.frames.length) { 
d=parent.frames[n.substring(p+1)].document; n=n.substring(0,p):} 
if(!(x=d[n])&é&d.all) x=d.all[n]; for (i=0;!x&&i<d forms.length:i++) x=d.forms[i][n]; 
for(i=0;!x&&d.layers&&i<d.layers.length:i++) x=MM_findObj(n,d.layers[i].document):; 
这 !x && d.getElementById) x=d.getElementById(n); return x; 
} 
function MM _swapImageO {//v3.0 
Var ij=0xX,a=MM _ swapImage.arguments: document.MM sr=new Aray: for(i=0;i<(a.length-2); 


if ((x=MM findObj(a[i]))!=nulD){document.MM sr[j++]=x; 这 !xX.oSrc) xXx.oSre=x.sre; 


} 

//--> 

</script> 

/下 面 的 代码 为 图 片 链接 相关 代码 

<a href="index.php" onMouseOut="MM_swapImgRestore0” 

onMouseOver="MM_swapImage(Imagel',",'images/an_1_1.gif,TD"> 

<img src="images/an_1.gif" alt=" 网 站 首页 " name="Imagel" border="0" id="Imagel" /></a> 

<a href="gsintro.php" onMouseOut="MM_ swapImgRestoreO" 

onMouseOver="MM._ swapImage('Image2',","images/an_2_1.gif',1)"> 

<img src="images/an_2.gif" alt=" 公 司 简介 " name="Image2" border="0" id="Image2" /></a> 

<a href="#" on MouseOut="MM._ swapImgRestoreQ|" 

‘onMouseOver="MM._ swapImage('Imagel1l1',",'images/an_1_1.gif',1)"></a> 
/省 略 部 分 代码 


(4) 在 index.php 文件 中 ， 通 过 <marquee> 标 签 滚动 输出 网 站 最 新 活动 、 公 司 新 闻 ， 
有 关 最 新 活动 滚动 输出 的 内 容 将 在 4.4 节 进 行 详细 讲解 ， 这 里 介绍 循环 输出 本 网 站 友情 链 
接 的 地 址 ， 其 关键 代码 如 下 : 

代码 位 置 : 配套 资源 \mr\04\index.php 


01 
02 
03 


<table width="222" border="0" cellspacing="0" cellpadding="0"> 
<?php 
$sql=mysql_query("select * from link order by lid desc");// 从 数据 库 中 查询 友情 链接 的 数据 
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Sinfo=mysql_ fetch_array($sqD); // 获 取 查 询 结果 
if($info){ 

dof /循环 输出 查询 结果 
> 

<tr> 

<td width= "48" height="26" align="right"><span class= "word white">-</Span>&nbsp:</td> 

<td width="134"> 
<a href="<?php echo $info[url]; ?>" target= ”parter" > 

<?php 

echo chinesesubstr($info[name],0,40):; /对 超 长 数据 进行 截取 输出 

这 strlen($info[name])>40){ 

ool ns 

EB 

?> 
</a></td> 
<td width="40">&nbsp;</td> 

</tr> 
<?php 

}while($info=mysql_fetch_array($sql)); 
</table> 


| (5) 在 index.php 页 的 主 位 置 中 循环 输出 5 个 产品 的 信息 介绍 ， 并 创建 查看 产品 详细 
| 信息 的 超 链接 。 有 关 此 内 容 将 在 4.5 节 进 行 详细 讲解 。 

| (6) 在 index.php 文件 中 ， 通 过 include 语句 包含 mr_bottom.php 网 站 尾 文件 ， 在 此 文 
| 件 中 输出 公司 的 一 些 信息 以 及 网 站 的 访问 量 ， 其 关键 代码 如 下 : 


代码 位 置 : 


配套 资源 mm\04\mr_bottom.php 

<td width="613" align="center" valign="bottom" class="stylel"> 您 是 明日 科技 软件 网 的 第 

<?php 

Simagenum=intval(Snumber); // 获 取 网 站 访问 量 的 整数 值 

for(Si=0;Si<8-strlen(Simagenum);Si++){ // 数 字 不 足 8 位 以 0 图片 补 齐 
echo "<img src=images/count/0.gif>"; // 输 出 数字 图 片 

} 

for($i=0;Si<strlen(Simagenum);Si++){ /循环 输出 网 站 访问 量 的 数字 图 片 值 
echo "<img src=images/count/".substr(Simagenum,$i,1).".gif>"; 

} 

?> 

位 访客 </td> 


(7) 在 index.php 文件 的 最 后 ， 定 义 一 个 自 定 义 函数 chinesesubstr0， 对 页 面 中 输出 的 


01 
02 


内 容 进行 截取 操作 ， 以 此 来 控制 页 面 中 输出 的 内 容 过 长 ， 提 高 页 面 的 美观 程度 。 自 定义 函 
数 chinesesubstr0 的 语法 如 下 : 
代码 位 置 ， 


配套 资源 \mr\04\index.php 


<?php 
function chinesesubstr($str, $start, $len){ // 自 定义 函数 截取 中 文字 符 串 
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03 Sstrlen=$start+ $len:; // 获 取 字 符 串 的 长 度 

04 for($i=0;$i<$strlen:$i++){ // 对 字 节 进行 循环 输出 
05 if(ord(substr($str,$i,1))>0xa0){ 1/ 判断 如 果 字 节 是 中 文字 符 串 
06 S$tmpstr.=substr($str, $1,2); /那么 每 次 截取 两 个 字 节 
07 Sitt; 

08 yelse{ 

09 Stmpstr.=substr($str,$i,1); /否则 每 次 截取 一 个 字 节 
10 } 

11 } 

12 return $tmpstr; // 返 回 截取 的 字符 串 

1330 

14 > 


4.4 最 新 活动 模块 设计 
4.4.1 最 新 活动 模块 概述 
在 网 站 首页 页 面 左 侧 下 方 显示 了 本 站 的 最 新 活动 信息 ， 以 便 让 用 户 能 够 及 时 了 解 网 站 


的 最 新 动态 ,运行 效果 如 图 4.11 所 示 。 当 用 户 单 击 活动 标题 超 链接 时 ,将 显示 活动 的 详细 
内 容 ， 运 行 效果 如 图 4.12 所 示 。 


， 明日 科技 管理 体制 


本 理惠 | 
计划 落实 任务 | 
i ED | 
科技 有 限 公司 | 
图 4.11 最 新 活动 信息 图 4.12 公告 详细 信息 


4.4.2 ”使 用 <marquee> 标 签 实现 文字 滚动 效果 


最 新 活动 版 块 中 以 自 下 而 上 的 滚动 方式 显示 活动 信息 ， 主 要 是 应 用 HIML 语言 的 
<marquee> 标 记 实 现 的 。 使 用 <marquee> 标 记 可 以 实现 文字 或 图 片 的 滚动 效果 ,在 增强 实用 | 
性 的 同时 ， 也 提高 了 观赏 性 。 下 面 将 介绍 <marquee> 标 签 的 常用 属性 和 方法 。 | 


1.<marquee> 标 签 的 文字 移动 属性 


<marquee> 标 签 的 特点 是 可 以 使 文字 或 图 片上 下 移动 。 早 期 ， 这 是 一 个 了 不 起 的 技术 ，| 
随 着 W3C 标准 的 逐渐 完善 ，<marquee> 标 签 已 经 较 少 使 用 。 但 有 些 技术 是 永远 不 变 的 ， 如 | 
对 于 <marquee> 标 签 中 的 属性 名 称 和 属性 值 ， 了 解 CSS 样式 表 和 JavaScript 脚本 语言 的 人 会 | 
感觉 到 非常 熟悉 ， 因 为 这 些 属性 名 称 和 属性 值 都 经 常 被 担 及 和 使 用 。<marquee> 标 签 常用 的 | 
文字 移动 属性 及 说 明 如 表 4.7 所 示 。 | 


ds L_ 


属性 名 称 属性 说 明 应 用 举例 
标签 基本 语法 ， 除 文字 以 外 ， 
还 可 以 是 图 片 
文字 移动 属性 ， 分 别 表示 从 右 
direction leftrightup,down ”| 往 左 、 从 左 往 右 、 从 下 到 上 、 
从 上 到 下 
文字 移动 方式 ， 分 别 表示 沿 同 
behavior scroll,slide,alternate | 一 方向 不 停 地 滚动 、 只 滚动 一 
次 、 在 两 个 边界 内 来 回 滚动 
循环 次 数 ， 不 指定 则 表示 为 无 | <marquee loop=5 behavior=slide> 只 
限 循环 循环 滚动 3 次 </marquee> 


于 | 酒 起 来 
scrollmount | 数值 10.20,30-… | 滚动 速度 ， 数 信 越 大 ， 速 度 越 快 | marquee scrolimount 25> 我 漂 起 来 
了 ! ! </marquee> 


SE 、 | <marquee scrolldelay="500" scrollamount 
… | 延 时 ， -次 ， 停 止 的 由 
scrolldelay | 数值 100,200,300… | 延 时 ， 每 动 一 次 ， 停 止 的 时 间 -100> 停 停 走 走 < 


2. <marquee> 标 签 的 外 观 设置 
<marquee> 标 签 不 仅 可 以 设置 文字 移动 效果 ， 还 能 设置 标签 的 外 观 。 外 观 包括 对 齐 方 
式 、 标 签 底 色 、 面 积 等 ，<marquee> 标 签 常用 的 外 观 属性 及 说 明 如 表 4.8 所 示 。 
表 4.8 <marquee> 标 签 常用 的 外 观 属性 及 说 明 


属性 说 明 


指定 文本 的 对 齐 
方式 


滚动 栏 颜色 


3.，<marquee> 标 签 的 其 他 属性 
除了 以 上 的 常规 设置 , <marquee> 标 签 还 有 两 个 特殊 的 属性 : start0 和 stop(。JavaScript 
脚本 语言 与 <marquee> 标 签 一 起 使 用 ， 可 以 制作 出 非常 别致 的 页 面 效果 ， 例 如 : 


onMouseOut="this.startO"; // 当 鼠标 指针 移出 该 区 域 时 ， 开 始 滚动 
onMouseOver="this.stopO"; // 当 鼠标 指针 进入 该 区 域 时 ， 停 止 滚动 


<marquee> 你 好 ，PHP</marquee> 


<marquee direction="up"> 从 下 到 上 
移动 <marquee> 


<marquee behavior="scroll"> 不 停 地 
循环 播放 </marquee> 


loop 数值 1,2,3… 


align top,middle,bottom <marquee align="middle> 我 在 中 间 </marquee> 


<marquee bgcolor="#DEEBEF"> 看 到 了 吗 ? 
bgcolor 颜色 值 #000000 ed 


数值 10,20,30… <marquee height="15"> 不 要 , 太 矮 了 </marquee> 
<marquee width="100"> 哇 ! 好 大 的 房子 啊 


</marquee> 


width 数值 10,20,30… 


4.4.3 ”最 新 活动 标题 滚动 显示 实现 过 程 
首先 设计 表单 页 面 ， 效 果 如 图 4.13 所 示 。 
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图 4.13 最 新 活动 表单 | 

页 面 设 计 完 成 后 ， 在 页 中 输出 活动 标题 信息 以 及 设计 标题 滚动 效果 。 数 据 从 数据 库 中 
通过 while 语句 循环 读 取 ， 并 且 通 过 自 定义 函数 chinesesubstr0 控 制 标题 输出 的 长 度 在 40 | 
个 字 节 之 内 ， 如 果 超 出 范围 则 以 省 略 号 补 齐 。 通 过 <marquee> 标 签 控制 数据 的 上 下 滚动 , 其 | 
关键 代码 如 下 : 


代码 位 置 ， 配 套 资 源 \mr\04\index.php 


01 <marquee direction="up" height="100" onMouseOut='"this.start0" 


02 onMouseOver='""this.stop0" scrollamount=1 scrolldelay="10"> | 
03 <table width="222" border="0" cellspacing="0" cellpadding="0"> | 
04 <?php | 
05 ”$sql=mysql_query("select * from affiche order by aid dese");// 查 询 数 据 库 中 数据 | 
06 S$info=mysql fetch_array($sqD); // 获 取 查 询 结果 | 
07 if(Sinfo){ // 浏 断 查询 结果 是 否 存在 | 
08 dof /循环 输出 查询 结果 | 
09 ?> | 
10 <tr> | 
11 <td width="48" height="30" align="right"><span class="word_white">-</span>&nbsp;</td> | 
i <td width="133"> | 
13 <a href="affiche.php?aid=<?php echo $info['aid']: ?>" target="_blank"> | 
14 <2php | 
15 echo chinesesubstr(Sinfo['title'],0,40); /截取 输出 活动 标题 | 
16 if(strlen(Sinfo['title'])>40){ /如 果 标 题 长 度 超过 40 个 字 节 | 
17 echoneeus // 以 省 略 号 补 齐 | 
18 } | 
19 ?> | 
20 </a></td> | 
2 <td width="41">&nbsp:</td> | 
22 </t> | 
23 <2php | 
24 }while($info=mysql fetch_array($sql)); | 
25 | 
26 > | 
27 </table> | 


28 </marquee> | 
4.4.4 查看 活动 详细 信息 实现 过 程 | 


当 用 户 单 击 活动 标题 超 链 接 时 ， 将 进入 该 活动 的 详细 信息 页 面 ， 活 动 详细 信息 页 面 的 
运行 结果 如 图 4.14 所 示 。 
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编程 词典 座 读 会 
本 公司 将 要 举行 编程 间 典 座谈 会 ， 现 诚 洲 广 大 读者 参加 
发 布 时 间 2011-04-20 00:46:53 
‖ 关闭 窗口 习 


te 
图 4.14 活动 详细 信息 页 


| 实现 活动 详细 信息 页 affice.php， 其 关键 是 根据 超 链接 传递 的 ID 值 ， 从 数据 库 中 查询 
| 出 指定 记录 的 数据 ， 并 且 输 出 查询 结果 ， 其 关键 代码 如 下 : 
代码 位 置 ， 配套 资源 \mr\04\affiche.php 


01 <?php 
02 include "Conn/conn.php"; // 包 含 数据 库 连接 文件 
| 03 $aid=$_GET['aid']; // 获 取 超 链 接 传递 的 人 D 值 
| 04 > 
| 05 <?php 
| 06 Sinfo=mysql_query("select * from affiche where aid='$aid'"); /执行 查询 语句 
| 07 Sresult=mysql fetch_array(Sinfo); // 获 取 查 询 结果 
| 08 ?> 
| 09 <table width="490" bordercolor="#CCCCCC" class="tableBorder LRB_dashed"> 
| 10 <t> 
| 11 <td height="27" colspan="2" align="center"><?php echo Sresult['title']; ?></td> 
| 12 </tr> 
| 13 <tr> 
| 14 <td height="26" colspan="2">&nbsp;&nbsp:<?php echo Sresult["content']; ?></td> 
| 15 </t> 
| 16 <tr> 
| 17 <td width="81" height="23" align="center"> 发 布 时 间 </td> 
| 18 <td width="409">&nbsp:&nbsp:&nbsp:&nbsp:<?php echo Sresult['atime']; ?></td> 
! 19 </t> 
| 20 <tr> 
| 21 <td height="25" colspan="2" align="center"> 
| 22 <a onClick="javascript:window.closeO:"><img src="images/close.gif' border 
| ="0"></a> 
| 23 </td> 
| 24 </tr> 
| 25 </table> 


| 4.5 产品 中 心 模块 设计 


4.5.1 产品 中 心 模块 概述 


| 在 首页 页 面 右 侧 为 软件 产品 展示 区 ， 即 产品 中 心 。 产 品 中 心 主要 用 于 展示 软件 产品 ， 
| 让 用 户 了 解 每 个 软件 的 详细 信息 。 产 品 心 运行 效果 如 图 4.15 所 示 , 此 处 展示 了 软件 的 图 
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片 、 名 称 和 介绍 等 相关 信息 ， 单 击 “ 详 细 ” 按 钮 ， 可 查看 软件 的 详细 信息 。 | 


【 Cs 泡 程 司 由 】 
人 EPE [这 汪 上 放生 有 全 各 技 不 广 


买 - 好 
Fs 式 和 铺 助 开发 内 容 《 轩 助 记 典 、 工 具 集 、 百 宇 箱 ，12 次 有 限 升 红 


【 ASF net 编程 司 奥 】 
了 阅 和 内容 名 A 并 入 站 之 学 习 和 和 有 
35 小 时 开 : 行业 发 ,10 个 行 = 
让 长 内 容 (技术 们 陪 技巧 模块 项目 界面 Tt 
)， Re 


于 天 


人 we 内 容 包 合 Yi sual C++ 篇 程 入 门 技能 学 习 与 
程 发 录 济 ， Ne J 

1 交代 和 人 实例、 技巧、 种 块 

等 海量 资源 ) ,四 种 各 能 查 : A 二 百 

宝箱 ) ，12! A 


评 调 


【 VE 护 程 局 办 】 
> 《Vi susl Basic 编 程 全 能 词 奥 ) 内容 包 合 Vin ic 篇 程 入 门 技能 学 
恒久 全 各 技术 支持 ，27 小 时 开发 录像 。13 站 和 人 
可 容 ( 技术 、 实 铀 ， 技 巧 、 和 


寺 吉 量 半 提 办 秋江 和 内 有、 TR 
宝箱 ) ，12 次 有 限 升 全 


训 末 


【 java 编程 词典 】 


srs 纺 程 全 能 词 奥 》 内 容 包 合 Jw 和 生生 人 和 于 是 绝 及 人生 
相持 小 时 放 果 入， 1 站 且 业 项 目 开发 ，10 个 行业 项 目 
开发 内 容 《 技术 、 实 例 、 扶 巧 、 模 块 、 项 目 、 界 面 - ry 也 | 
pHi 方式 和 内 和 《办 司 工具 介 、 百 宝 茶 ) ，12 次 免费 


EE 


图 4.15 软件 产品 中 心 
4.5.2 do...while 循环 输出 查询 结果 


产品 中 心 模块 在 输出 数据 库 中 的 软件 产品 信息 时 使 用 do.…while 循环 语句 ，do...while | 

语句 是 循环 控制 语句 中 的 一 种 ， 使 用 方式 和 while 相似 ， 也 是 通过 判断 表达 式 的 值 来 输出 | 

循环 语句 的 ， 其 语法 如 下 : | 

dof 并 

程序 在 未 经 判断 之 前 就 进行 了 一 次 循环 ， 循 环 到 while 部 分 才 判 断 

statement; 。 条 件 ， 即 使 条 件 不 满足 ， 程 序 也 已 经 运行 了 一 次 

4/ 

}while(exp?); | 

该 语句 的 操作 流程 是 ， 先 执行 一 次 指定 的 循环 体 语句 ， 然 后 判断 表达 式 的 值 ， 当 表达 | 

式 的 值 为 非 0 时， 返回 重新 执行 循环 体 语句 ， 如 此 反复 ， 直到 表达 式 的 值 等 于 0 为 止 , 此 | 

时 循环 结束 。 其 特点 是 先 执行 循环 体 ， 然 后 判断 循环 条 件 是 否 成 立 。do.…while 循环 语句 | 
的 操作 流程 如 图 4.16 所 示 。 


| 
| 
! 
| 
| 
| 
| 
| 
! 
| 
上 
! 
| 
| 
| 
| 
| 
| 
! 
| 
E 
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A 人 Ptp 项目 案例 分 析 
有 


循环 体 语句 
网 当 表 达 式 值 为 真 
| Ca) (pb) 
图 4.16 do...while 循环 语句 的 操作 流程 


4.5.3 “<img> 标 签 输出 产品 效果 图 


在 产品 中 心 页 面 中 输出 产品 图 片 使 用 <img> 标 签 ， 关 键 代码 如 下 : 

img sre—"<2php echo " /upload/" $info[fileimage]: 2>" width="110" height="130" class="tableBorder"> 
| <img> 标 签 并 不 是 在 网 页 中 插入 图 像 ,而 是 从 网 页 上 链接 图 像 ，<img> 标 签 创建 的 是 被 
| 引用 图 像 的 占 位 空间 。 
| <img> 标 签 的 常用 属性 介绍 如 下 。 
回 ”src 属性 : src 属性 是 必需 的 ， 其 值 是 图 像 文件 的 URL， 也 就 是 引用 图 像 的 文件 的 
绝对 路 径 或 相对 路 径 。 
height 属性 : 表示 图 片 的 高 度 ， 可 以 是 数值 ， 也 可 以 是 百分比 。 
width 属 生 : 表示 图 片 的 宽度 ， 可 以 是 数值 ， 也 可 以 是 百分比 。 
vspace 属性 : 表示 垂直 方向 上 图 片 距 上 一 个 网 页 元 素 的 距离 。 
hspace 属性 : 表示 水 平方 向 上 图 片 距 左边 网 页 元 素 的 距离 。 
border 属性 : 表示 图 片 的 边框 。 
aligh 属性 : 表示 图 片 相 对 于 文件 基准 线 (文字 中 线 ) 的 水 平 对 齐 方 式 , 可 以 取 的 
值 有 top (上 对 齐 ) 、bottom (下 对 齐 ) 、middle (中间 对 齐 ) 、left( 左 对 齐 )、 
right ( 右 对 齐 ) 。 
lowsrc 属性 : 表示 所 链接 的 低 分 辨 率 的 图 片 的 地 址 ， 低 分 辩 率 的 图 片 要 比 高 分 辨 
率 的 图 片 文件 小 。 所 以 在 网 络 传输 塞车 时 先 强 行 传输 低 分 辨 率 的 图 片 ， 该 图 片 显 
示 完 毕 后 再 传 src 所 指定 的 图 片 。 
回 alt 属性 : 表示 当 鼠 标 指针 放 在 图 片上 时 显示 的 文字 。 


4.5.4 显示 软件 产品 实现 过 程 


显示 软件 产品 的 实现 过 程 如 下 。 
(1) 首先 设计 表单 页 面 ， 设 计 效果 如 图 4.17 所 示 。 


加 罗网 罗网 加 


[al 


| 图 417 产品 中 心 页 面 设计 效果 
J “138 。 
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(2) 页 面 设计 完成 后 ， 在 页 面 的 相应 位 置 输出 数据 库 中 的 产品 信息 。 通 过 mysql query0 
函数 执行 SQL 语句 ， 读 取 数 据 库 中 存储 的 数据 。 通 过 mysql_fetch_array0 函 数 获取 查询 结 
果 。 通 过 do...while 语句 完成 查询 结果 的 循环 输出 ， 其 关键 代码 如 下 : 

代码 位 置 : 配套 资源 \mr\04\index.php 


Eo 
02 S$sqE=mysql query("select* from soft orderby uptime dese limitS"); /查询 数据 库 中 数据 | NOR 
03 Sinfo=mysql fetch_array($sqD); // 获 取 查 询 结果 | 
04 if(Sinfo){ | 
05 do{ | 
06 > | 
07 <table width="531" border="0" cellspacing="0" cellpaddine="0"> | 
08 <tr> | 
09 <td width="549"> | 
10 <table width="543" border="0" cellspacing="0" cellpadding="0"> | 
11 <tr align="left"> | 
12 <td width="543" height="127" align="center"> | 
13 <table width="100%" border="0" cellpadding="0" cellspacing="0"> | 
14 <tr> | 
15 <td width="26%" rowspan="3" align="center" valign="middle"> | 
16 <img src="<?php echo "./upload/".$info['fileimage']: ?>" class="tableBorder"> | 
17 </td> | 
18 <td height="33" colspan="2"> | 
19 <p><font color="#DD2606">【 &nbsp:<?php echo $infofname']; ?>&nbsp;】 | 
/ont></p> | 
20 </td> | 
21 </tr> | 
2 <tr> | 
23 <td height="95" colspan="2" valign="top">&nbsp;&nbsp:;&nbsp;&nbsp:; | 
24 <font color="#666666"><?php echo $info['introduce']: ?><br></font> | 
25 </td> | 
26 </tr> | 
27 <t> | 
28 <td width="58%" height="13" valign="top">&nbsp:</td> | 
29 <td width="16%" valign="top"> | 
30 <a href="soft_list.php?filename=<?php echo urlencode(Sinfo['softhtml']);?>"> | 
31 <img src="images/more-hb.gif' width="43" height="16"> | 
32 </a> | 
33 </td> | 
34 </tr> | 
35 </table> | 
36 </table> | 
37 <hrsize="l"></d> | 
38 <t> | 
39 ”<?php | 
40 }while($info=mysql fetch_array($SsqD): | 
41 j}else{ | 
7 | 
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| Er 
从 
| EE <tr align="center"><td> 暂 无 产品 信息 ! </td></t> 
| 44 <?php 
| 45 } 
46 > 
47 </table> 


| 4.5.5 ”查看 产品 详细 信息 实现 过 程 

| 当 用 户 单 击 “ 详 细 ” 超 链接 后 ， 将 进入 软件 产品 详细 信息 页 (soft listphp )， 在 
| soft_list.php 文件 中 ， 根 据 超 链接 传递 的 参数 值 ， 从 数据 库 中 读 取出 软件 产品 的 详细 信息 。 
| 如 果 软 件 存 在 ， 则 输出 软件 详细 信息 ， 并 且 创建 软件 下 载 的 超 链接 ， 其 关键 代码 如 下 : 

| 代码 位 置 ， 配套 资源 \mr\04\soft_list.php 


| 01 <?php 

| 02 include "Conn/conn.php"; 

| 03 $filename=urldecode($_GET['filename']); // 获 取 超 链 接 传递 的 参数 值 
| 04 > 

| 05 <?php 

| 06 $sql=mysql query("select* 位 om soft where softhtml='$filename"); /执行 查询 语句 

| 07 $info=mysql fetch array($sq)); // 获 取 查 询 结果 

| 08 if($infof'softhtml]!=""){ // 判 断 查 询 结果 是 否 存 在 

| 09 include "soft/". $info['softhtml ]; /输出 软件 详细 介绍 信息 

| 10 echo "<a href='soft/".$info['softdown']." title= 点击 即 可 下 载 ! >". 

| 11 "<img src='"upload/".$info['fileimage']." width='250' height='100' border="0'></a>";// 创 
| 建 下 载 超 链接 

| 12 Jelse{ 

| 13002 

| 14 <tr align="center"> 

| 15 <td height="22"> 暂 无 软件 资源 信息 </td> 

| 16 </tr> 

| 17 <?php 

| I 

| 19 ?> 


| 4.5.6 ”查看 更 多 产品 信息 实现 过 程 


当 用 户 单 击 “ 更 多 ” 超 链 接 后 ， 将 显示 所 有 软件 产品 ， 在 该 页 面 中 增加 了 分 页 功能 ， 
以 分 页 的 形式 完成 软件 产品 的 循环 输出 ， 其 关键 代码 如 下 : 


| 代码 位 置 ， 配套 资源 \mr\04\list_softsort.php 


| 01 <?php 
| 02 if(!isset($_GET['page']){ // 判 断 分 页 变量 是 否 存 在 
| 03 Spage=1; // 定 义 初始 值 为 1 

04 }else{ 

05 Spage=$_GET['page']; // 为 分 页 变量 赋值 

06 } 
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07 if($page){ 

08 Spage_size=5; // 定 义 每 页 显示 记录 数 

09 Squery="select count(*) as total from soft order by sfid desc"; /定义 查询 语句 

10 Sresult=mysql_query(Squery); /执行 查询 语句 

11 Smessage_count=mysql_result($Sresult,0,"total");// 获 取 查 询 记 录 总 数 

12 Spage_count=ceil(Smessage_count/Spage_size); // 计 算 页 码 

13 Soffset=(Spage-1)*Spage_size; // 定 义 每 页 的 开始 位 置 

14 for ($i=]1; $1<2; $iH+){ /执行 for 循环 输出 

15 于 (9i 一 1){ 

16 S$sql=mysql_query("select * from soft order by sfid desc limit Soffset, 
Spage_size"); 

17 } 

18 $info=mysql fetch_array($sq)); 

19 } 

20 if($info){ 

21 dof{ /循环 输出 查询 结果 

.4 Ta 

| <table width="531" border="0" cellspacing="0" cellpadding="0"> 

24 <tr> 

25 <td width="549"> 

26 <table width="100%" border="0" cellpadding="0" cellspacing="0"> 

2 <tr> 

28 <td width="26%" rowspan="3" align="center" valign="middle"> 

29 <img src="<?php echo "./upload/".Sinfo['fileimage’]; ?>" 
class="tableBorder"> 

30 </td> 

31 <td height="33" colspan="2"><p> 

32 <font color="#DD2606">【 &nbsp:<?php echo S$info['name']; ? | 
>&nbsp;】</fonf></p> 

33 </td> 

34 </tr> 

35 <tr> 

36 <td height="95" colspan="2" valign="top"> 

3 <font color="#666666"><?php echo Sinfo['introduce']; ? > |! 
<br></font> 

38 </td> 

39 </tr> 

40 <tr> 

41 <td width="58%" height="13" valign="top">&nbsp;</td> 

42 <td width="16%" valign= "top"> 

43 <a href="soft list.php?filename=<?php echo urlencode($info 
[softhtml']);?>"> 

44 <img src="imagesmore hb.gif' width="43" height="16"> 

45 </a> 

46 </td> 

47 </tr> 

48 </table><hr size="1"> 

49 </td> 

50 </tr> 


上 
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Le 

51 ”<?php 

32 }while($info=mysql fetch_array($sqD): 

53 jelsef 

54 > 

55 <tr align="center"> 

56 <td> 没 有 添加 软件 产品 </td> 

5 </t> 

58 <?php 

59 } 

60 -> 

61 </table> 

62 <table width="531" border="0" align="center" cellpadding="0" cellspacing="0"> 

63 <tr bgcolor="#EFF7DE"> 

64 <td width="361" bgcolor="#EFEFEF">&nbsp;&nbsp; 页 次 <?php echo $page;?> 

65 /<?php echo $page count;?> 页 &nbsp; 记录 : ”<?php echo $message_ 
count:?>&nbsp; 条 </td> 

66 <td width="170" align="right" bgcolor="#EFEFEF" class="hongse01"> 

67 <?php 

68 if(Spage!=D){ // 分 页 超 链 接 

69 echo "<a href=list_softsort.php?page=1 class= 仑 首页 </a>&nbsp;"; 

70 echo "<a href=list_softsort.php?page=".($page-1)." class=f> 上 一 页 </a>&nbsp;"; 

zi 

2 if(Spage<Spage_count){ 

3 echo "<a href=list_softsort.php?page=".($page+1)." class=f> 下 一 页 </a>&nbsp;"; 

74 echo "<a href=list_softsort.php?page=".Spage_count." class=f> 尾 页 </a>"; 

75 

76 } 

77 2> 


4.6 客户 反馈 模块 设计 


4.6.1 客户 反馈 模块 概述 
客户 反馈 模块 主要 实现 发 表 留言 及 查看 留言 详细 信息 的 功能 ， 在 页 面 左 侧 导 航 菜单 中 


单 击 “客户 反馈 ” 超 链接 ， 可 进入 客户 反馈 页 面 ， 如 图 4.18 所 示 。 单 击 “ 添 加 留言 ” 超 链 


接 ， 可 进入 添加 留言 页 面 ， 如 图 4.19 所 示 。 留 言 添加 成 功 后 ， 由 管理 员 在 后 台 对 留言 进行 


回复 及 审核 ， 审 核 成 功 后 将 显示 在 首页 。 


是 否 回复 发 布 时 间 
2011-04-19 


2011-04-19 


如 加 加 


2011-04-19 


页 次 1 页 记录 : 3 条 


图 4.18 客户 反馈 页 面 运行 效果 
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图 4.19 添加 留言 页 面 运行 效果 
4.6.2 ”数字 验证 码 
客户 反馈 模块 使 用 mt_rand() 函 数 来 初始 化 一 组 4 位 的 随机 数 ， 并 应 用 for 循环 语句 随 
机 生成 4 位 验证 码 ， 然 后 利用 数字 图 形 输 出 到 浏览 | 
(1) mt_rand() 函 数 
mt_rand0 函 数 主要 用 于 获取 随机 数值 。 其 语法 格式 如 下 : 
int mt_rand([int min], [int max]); | 
数字 验证 码 主要 应 用 mt_rand() 函 数 获得 。 该 函数 主要 用 于 从 指定 参数 中 取 一 个 数字 ， 
例如 : | 
mt rand(52,79) 
将 会 从 52 一 79 之 间 取 一 个 随机 数值 。 
(2) intval0 函 数 
intval0 函 数 主要 用 于 将 变量 转 成 整数 类 型 。 语 法 格式 如 下 : 
int intval(mixed var, int [base]): | 
可 省 略 的 参数 base 是 转换 的 基底 , 默认 值 为 10。 转换 的 变量 var 可 以 为 数组 或 类 之 外 | 
的 任何 类 型 变量 。 | 


4.6.3 留言 信息 分 页 浏览 


当 用 户 单 击 “客户 反馈 ” 超 链接 后 ， 将 进入 客户 信息 反馈 页 面 ， 循 环 输出 客户 留言 信 | 
息 。 在 guestboard.php 文件 中 ， 读 取 留 言 信息 表 中 的 数据 ， 并 且 对 数据 进行 分 页 循环 输出 ， | 
其 关键 代码 如 下 : | 

代码 位 置 : 配套 资源 \mr\04\guestboard.php 

01 <table width="535" border="1" cellspacing="1" bordercolor="#dddddd" class="tableBorder2"> 


02 <tr align="center" bgcolor="#EDEDED"> 
03 <td width="64%" height="27"> 留 言 标题 </td> 
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22 


23 


30 
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td width-"1896" align-"center' 必 是 否 回 复 <jtd> 
<td width="18%" align="center"> 发 布 时 间 </td> 


</tr> 

<?php 

if(!isset($_GET['page'])) { // 判 断 分 页 变量 是 否 存 在 
Spage=1; // 定 义 初始 值 为 1 

jelsef 
Spage=$_GET['page']; // 获 取 分 页 变量 的 值 

} 

if (Spage){ 
Spage_size=15; // 定 义 每 页 显示 15 条 记录 
Squery="select count(*) as total from guestboard order by gid desc"; /定义 查询 语句 
Sresult=mysql_query(Squery); // 执 行 查询 语句 
Smessage_count=mysql_result(Sresult,0, "total"); // 统 计 总 的 记录 数 
Spage_count=ceil(Smessage_count/Spage_size); 1/ 计算 总 的 页 码 
Soffset=(S$page-D*Spage_size; /计算 每 页 的 开始 位 置 
for ($i=1; $1<2; $i++H){ 

if($i==1D){ 


$sql=mysql query("select * from guestboard where gshow=] order by gid desc limit $offset, 


Sresult=mysql fetch_array($sq)); 
} 
if($resull){ 
dof /循环 输出 查询 结 


<tr align="left" bgcolor="#FFFFFF"> 
<td height="28">&nbsp:&nbsp;<img src="images/admin ico.gif' width="7" height="7"> 
<a href="guestboad list.php?gid=<?php echo Sresult['gid'];?>" target= 


"_blank" class="style2"> 


| 
32 


<2php echo $result['title'];?></a></td> 
<td height="28" align="center"><?php if($result['recontent]<>""){ echo "是 ";} 


else{echo " 否 ";}?></td> 


33 
34 
3 
36 
37 
38 


<td height="28" align="center"><?php echo $result['gtime']:?></td> 


</tr> 
<?php 
}while($result-mysql_fetch_array($sqD): 
jelse{ 
?> 
<tr align="center" bgcolor="#F7F7F7"> 
<td height="27" colspan="3"> 当 前 留言 为 空 </td> 
</t> 
<?php 
> 
</table> 


4.6.4 查看 留言 详细 信息 


当 上 


户 和 


击 留 言 标题 超 链接 时 , 将 进入 留言 详细 信息 页 面 , 即 可 查看 详细 的 留言 信息 。 
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在 guestboad listphp 文件 中 ， 根 据 超 链接 传递 的 ID 值 ， 从 数据 库 中 查询 出 指定 记录 的 详 
细 信 息 ， 其 关键 代码 如 下 : 
代码 位 置 ， 配 套 资源 \mr\04\guestboad _list.php 


01 <?php 

02 include "Conn/conn.php"; /连接 数 据 库 

03 $gidl=$_GET['gid']; /获取 超级 链接 传递 的 ID 值 
04 ?> | 
05 <2php | 
06 ”Sinfo=mysql query("select* from guestboard where gid='$gid1'"); /执行 查询 语句 | 
07 Sresult=mysql fetch_array(Sinfo); // 获 取 查 询 结果 | 
08 ?> | 
09 <table width="540" border="1" align="center" cellspacing="1" bordercolor="#CCCCCC"> | 
10 <tr> | 
11 <td width="102" height="25" align="center"> 留 言 标 题 </td> | 
2 <td width="425" align= left">&nbsp:&nbsp:<?php echo Sresult['title'];?></td> | 
13 </tr> | 
14 <tr> | 
15 <td height="23" align="center"> 留 言 时 间 </td> | 
16 <td align="left">&nbsp:&nbsp:&nbsp:&nbsp:<?php echo Sresult['gtime'];?></td> | 
Ii </t> | 
18 <u> | 
19 <td height="24" align="center"> 留 &nbsp; 言 &nbsp; 人 </td> | 
20 <td align="left">&nbsp:&nbsp:&nbsp:&nbsp:<?php echo Sresult["guest'];?></td> | 
2 </tr> | 
22 <tr> | 
23 <td height="24" align="center"> 留 言 内 容 </td> | 
24 <td align="left">&nbsp;&nbsp;&nbsp;&nbsp;<?php echo Sresult['content'];?></td> | 
25 </t> | 
26 <tr> | 
3 <td height="24" align="center"> 回 复 内 容 </td> | 
28 <td align="left">&nbsp;&nbsp:&nbsp;&nbsp;<?php echo Sresult['recontent'];?></td> | 
29 </tr> | 
30 <tr> | 
31 <td height="26" align="center"> 回 复 时 间 </td> | 
32 <td align="left">&nbsp:&nbsp:&nbsp:&nbsp:<?php echo Sresult['rtime'];?></td> | 
33 </t> | 
34 <tr align="center"> | 
35 <td height="29" colspan="2"> | 
36 <a onClick="javascript:window.close():"><img sre="images/close.gif"" border="0"></a> | 
37 </td> | 
38 </tr> | 
39 </table> | 


4.6.5 添加 留言 信息 


当 用 户 单 击 “ 添 加 留言 ” 超 链接 后 ， 将 进入 添加 留言 页 面 ， 填 写 完整 的 留言 标题 及 内 
容 ， 单 击 “ 提 交 留 言 ”按钮 ， 即 可 完成 添加 留言 操作 。 在 add_guestboard.php 页 面 中 ， 创 
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| 建 表单 ， 将 留言 信息 提交 到 check_guestboard.php 文件 ， 并 且 设 置 数字 验证 码 ， 其 关键 代 


| 码 如 下 : 
代码 位 置 ， 配 套 资源 \mr\04\add_guestboard.php 


01 <form name="myform" method="post" action="check_guestboard.php"> 
02 <input name="title" type="text" size="60"> 

03 <textarea name="content" cols="50" rows="8"></textarea> 

04 <input name="guest" type="text" size="30" value="” 匿名 "> 

05 <input type="text" name="txt yan"> 


06 <?php 

07 $num=intval(mt rand(1000,9999)); // 生 成 随机 验证 码 

08 for(G$i=0:$i<4:$itH{ /以 图 片 的 形式 输出 随机 验证 码 

09 echo "<img src=images/checkcode/".substr(strval($num),$i,1).".gif>"; // 输 出 随机 的 数字 图 形 
10 } 

11 > 

I <input type="hidden" name="txt_hyan" id="txt_hyan" value="<?php echo $num;?>" > 

13 <input type="submit" name="Submit' value=" 提 交 留 言 " onClick="return guestboad0;"> 

14 <inputtype="reset" name="Submit2" value=" 重 置 "> 

15 </form> 


| 在 check_guestboard.php 文件 中 ,获取 表单 提交 的 数据 ， 将 其 添加 到 指定 的 数据 表 中 ， 
| 其 关键 代码 如 下 : 
| 代码 位 置 ， 配 套 资源 \mr\04\check_guestboard.php 


01 <?php 
02 header("Content-type:text/html:charset=gb2312"); // 设 置 编 码 格式 
03 include "Conn/conn php": // 连 接 数 据 库 
04 iflisset($ POST['Submit']){ // 判 断 提交 按钮 值 是 否 存 在 
05 $title=$ POST['title]: /获取 表单 提交 的 数据 
06 $content=$_ POST['content]: 
07 $guest=$_ POST['guest]; 
08 $gtime=date("Y-m-d"): /获取 系统 当前 时 间 
09 $query—"insert into guestboard (title.content. guest.gtime) values( $title,'$content ‘Sguest,'Sgtime)"’; 
10 $result=mysql_query($query); /执行 添加 语句 
11 这 $resulb{ 
| 12 echo "<script> alert( 洪 加 成 功 !11); window.location href- guestboard.php': </script>"; 
| 13 }else{ 
| 14 echo "<script>alert( 添 加 失败 111):windowJocation href=:guestboard php':</script>"; 
| 15 } 
| Loe 
| T1701> 


4.7 后 台 主 页 设计 


| 4.7.1 后 台 主页 概述 


| 后 台 主 页 以 框架 的 形式 展示 出 后 台 管 理 系统 的 所 有 功能 ， 框 架 中 包含 网 站 头 文件 
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top.php， 左 侧 导 航 文件 leftphp 和 右 侧 功能 展示 区 文件 main.php。 功 能 展示 区 默认 输出 系 
统 提 示 信 息 。 后 台 主 页 的 运行 效果 如 图 4.20 所 示 。 | 


pi me 


用 思想 创 ; 
用 软件 改变 世界 用 


图 4.20 后 台 主页 运行 效果 | 
后 台 管 理 系统 的 功能 包括 管理 公司 活动 、 新 闻 信 息 、 软 件 类 别 、 软 件 产品 、 硬 件 产品 、! 
留言 短 、 常 见 问题 、 说 明 书 和 友情 链接 。 | 
4.7.2 后 台 主 页 框架 设计 原理 | 
后 台 主 页 框架 的 基本 结构 在 后 台 主 页 运行 效果 中 已 经 体现 出 来 了 ， 即 采用 一 行 两 列 的 
结构 设计 。 后 台 主 页 框架 应 用 frame 框架 技术 设计 ， 其 关键 代码 如 下 : | 
代码 位 置 ， 配套 资源 \mr\04\admin\index.php 
01 <frameset rows="*" cols="*,776,*" framespacing="1" frameborder="no" border="1" > 


02 <frame sre="#" name="blankFrame" scrolling="NO" noresize> 

03 <frameset rows="242,*" cols="*" framespacing="1" frameborder="no" border="1" > 
04 <frame sre="top.php" name="topFrame" scrolling="NO" noresize> 

05 <frameset rows="*" cols="179,*" frameborder="no" bordercolordark="#fftfff'> 
06 <frame src="left.php" name="leftFrame" scrolling="NO" noresize> 

07 <frame src="main.php" name="mainFrame"> 

08 </frameset> 

09 </frameset> 

10 <frame src="#"></frameset> 


11 <noframes> 


在 上 述 框架 代码 中 ， 要 特别 注意 07 行 中 定义 的 框架 名 称 ， 因 为 通过 超 链接 完成 在 不 | 
同 框架 之 间 的 跳 转 时 ， 必 须 使 用 框架 名 称 才 能 执行 调整 操作 ， 否 则 超 链接 找 不 到 所 指定 的 | 
文件 。 例 如 ， 在 左 侧 导 航 文件 leftphp 中 ， 当 单 击 “ 公 司 活动 管理 ” 超 链 接 时 ， 将 在 右 侧 | | 
展示 区 的 框架 中 输出 manage affiche.php 文件 中 的 内 容 。 英 下 转 的 关键 就 是 通过 超 链接 申 | 
target 属性 指定 框架 名 称 mainFrame。 其 设置 的 超 链 接 代码 如 下 : 
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<a href="manage_affiche.php" target="mainFrame" class=f><img src="../images/admin ico.gif" 
width="7" height="7"> &nbsp: 公 司 活动 管理 </a> 


4.7.3 后 台 主页 实现 过 程 


在 后 台 主 页 中 ， 主 要 通过 frame 框架 完成 后 台 管 理 系统 的 整体 设计 ， 其 中 有 关 框 架 文 
件 的 内 容 已 经 在 4.7.2 节 中 进行 了 介绍 。 这 里 讲解 的 框架 中 包含 3 个子 文件 :top.php、left.php 
和 main.php。 

(1) 在 top.php 中 ， 完 成 后 台 管 理 页 眉 的 设计 ， 其 设计 效果 如 图 4.21 所 示 。 


吉林 省 明日 科技 有 限 公司 
GRAINEA ht 


用 思想 创造 未 来 
用 软件 改变 世界 用 代码 书写 人 生 


图 4.21 后 台 管 理 系统 页 眉 


(2) 在 left.php 文件 中 ， 创 建 后 台 管 理 系统 的 导航 菜单 ， 分 别 为 不 同 的 功能 创建 超 链 
接 , 当 单 击 超 链接 时 , 在 右 侧 的 展示 区 框架 (mainFrame) 中 输出 具体 功能 操作 界面 。leftphp 
中 的 关键 代码 如 下 : 

代码 位 置 ， 配套 资源 \mr\04\admin\left.php 


01 <table width="90%" cellpadding="0" cellspacing="0" bgcolor="#EDF8FF"> 


02 <tr> 

03 <td height="20" style="padding:8px " class="tableBorder_T_dashed"> 

04 <a href="manage_affiche.php" target="mainFrame" class= 人 > 

05 <img src="../images/admin ico.gif' width="7" height="7"> &nbsp; 公 司 活动 
管理 

06 </a> 

07 </td> 

08 </tr> 

09 <tr> 

10 <td height="20" style="padding:8px " class="tableBorder T_dashed"> 

11 <a href="manage_news.php" target="mainFrame" class={> 

12 <img src="../images/admin_ico.gif" width="7" height="7"> &nbsp; 新 闻 
信息 管理 

13 </a> 

14 </td> 

15 </t> 

16 ”<!-- 省 略 部 分 代码 --> 

1 <tr> 

18 <td height="20" style="padding:8px" class="tableBorder _T_dashed"> 

19 <a href="manage_link.php" target="mainFrame" class= 仑 

20 <img src="../images/admin_ico.gif" width="7" height="7"> &nbsp; 友 情 
链接 管理 
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22 </td> 


凡 </tr> 

24 </table> | 

(3) mainphp 是 右 侧 展示 区 默认 的 文件 ， 在 该 文件 中 输出 一 个 后 台 管 理 系统 的 提示 | 请 一 
信息 ， 其 效果 如 图 4.22 所 示 。 


明日 科技 软件 后 台 管理 系统 : 


图 4.22 主 展示 区 默认 输出 内 容 
4.8 ”软件 产品 管理 模块 设计 


4.8.1 软件 产品 管理 模块 概述 


软件 产品 管理 模块 主要 用 于 对 软件 产品 信息 进行 添加 、 修 改 、 删 除 及 查询 操作 。 在 后 | 
台 管 理 系统 主页 左 侧 导航 菜单 中 ， 单 击 “ 软 件 产品 管理 ” 超 链接 ， 将 在 右 侧 展示 区 中 输出 | | 
如 图 4.23 所 示 的 功能 操作 页 面 。 | 


软件 产品 管理 

Ce | 证 加 昌 欢 件 
| 可 fs 别 | 欢 柏 名称。 | 。 上 全 时 间 。 | 下 载 当量 | 人 30/ 抽 除 
| 的 可 | C# 编 程 词 典 Em | | 
| 纺 程 闻 奥 | ASP.net 编 程 闻 奥 2011-04-19 0 
| 纺 程 记 奥 。 | java 护 程 词 和 Zuo Jo 他 修改 习 [ 由 删除 习 
| 编程 词 册 。 | vB 编 得 词 和 | 2011.0419 0 人 修改 司 ] 
| 编程 词典 。 | VC 编程 词典 ET 0 FT (TEIILEN 


页 次 11 页 记录 : 5 条 


图 4.23 软件 产品 管理 页 面 运行 效果 
4.8.2 文件 上 传 技术 扩展 


文件 上 传 技术 在 第 2 章 已 经 进行 了 系统 的 讲解 ， 包 括 如 何 使 用 move_uploaded file() 
函数 上 传 文件 、 如 何 通过 全 局 变量 $_FILES 对 上 传 文件 进行 判断 。 这 里 对 文件 上 传 技术 进 | 
行 一 下 扩展 ， 讲 解 如 何在 PHP 的 配置 文件 (php.ini) 中 对 上 传 文件 进行 控制 以 及 通过 表单 | 
中 隐藏 域 控 制 上 传 文件 大 小 。 
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1. 通过 php.ini 文 件 对 上 传 文件 进行 控制 
对 上 传 文件 的 控制 包括 是 否 支持 上 传 、 上 传 文件 的 临时 目录 、 上 传 文件 的 大 小 、 指 令 
执行 的 时 间 和 指令 分 配 的 内 存 空间 。 
在 php.ini 中 ,定位 到 File_Uploads 项 ， 完 成 对 上 传 相关 选项 的 设置 。 上 传 相关 选项 的 
含义 如 下 。 
file_uploads: 如 果 值 为 on， 说 明 服务 器 支持 文件 上 传 ， 如 果 为 off， 则 不 支持 。 
一 般 默认 是 支持 的 ， 不 用 修改 。 
upload tmp_dir: 上 传 文件 临时 目录 。 在 文件 被 成 功 上 传 之 前 ， 文 件 首先 存放 到 
服务 器 端的 临时 目录 中 。 多 数 使 用 系统 默认 目录 ， 但 是 也 可 以 自行 设置 。 
upload max filesize: 服务 器 允许 上 传 文件 的 最 大 值 ， 以 M 为 单位 。 系 统 默认 为 
2M， 如 果 网 站 需要 上 传 超过 2M 的 数据 ， 就 要 修改 该 值 。 
除了 上 述 File_Uploads 项 中 设置 的 与 上 传 相 关 的 内 容 之 外 , 在 php.ini 中 还 有 以 下 几 个 


| 选项 会 影响 到 文件 的 上 传 。 


| 注意: 


max_execution time: PHP 中 一 个 指令 所 能 执行 的 最 大 时 间 ， 单 位 是 s。 该 选项 在 
上 传 超大 文件 时 必须 要 修改 ， 和 否则 即使 上 传 文件 在 服务 器 允许 的 范围 内 ， 但 是 超 
过 了 指令 所 能 执行 的 最 大 时 间 ， 仍 然 无 法 实现 上 传 。 

memory_limit: PHP 中 一 个 指令 所 分 配 的 内 存 空间 ， 单 位 是 M。 其 大 小 同样 会 影 
响 到 超大 文件 的 上 传 。 


(1) php.ini 文 件 配置 完成 后 ， 需 要 重新 启动 Apache 服务 器 ， 配 置 才能 生效 。(2 ) 如 


| 果 使 用 集成 化 的 安装 包 来 配置 PHP 的 开发 环境 ， 那 么 就 不 必 担心 上 述 介绍 的 这 些 配置 信 


| 息 ， 因 为 默认 已 经 配置 好 。 ( 3 ) 如 果 要 上 传 超大 文件 ,那么 就 有 必要 对 php.ini 进行 修改 ( 即 


使 使 用 集成 化 安装 包 配 置 也 不 行 )。 修 改选 项 包括 upload_ max filesize， 允 许 上 传 文件 的 最 
大 值 ; max_execution time， 一 个 指令 所 能 执行 的 最 大 时 间 和 memory_limit, 一 个 指令 所 分 
配 的 内 存 空间 。 

2. 通过 表单 中 隐藏 域 MAX _ FILE _SIZE 的 值 来 控制 上 传 文件 的 大 小 


要 想 使 该 设置 生效 ， 必 须 将 隐藏 域 放置 在 上 传 文件 的 文件 域 之 前 ， 否 则 是 不 会 起 作用 
的 。 它 与 全 局 变量 $_FILES[filename][error] 中 的 第 3 个 返回 值 是 对 应 的 ， 表 示 上 传 文件 大 
小 超出 HTML 表单 中 MAX_FILE_SIZE 选项 所 指定 的 值 。 


4.8.3 添加 软件 信息 实现 过 程 


当 用 户 单 击 “ 添 加 新 软件 ” 超 链 接 时 ， 将 进入 软件 信息 添加 页 面 ， 运 行 效 果 如 图 4.24 
所 示 。 
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二 起 软件 产品 


Es 


Fr 注意 : ET a 


TEST 司 | 二 总 ; 上 人 不 更 大 于 50VB 


软件 文档 Decments ant SettincxWiain 村 窜 下 | 注意 ; 上 传 文档 为 .htm 梧 式 


ER 
上 本 直 赤 拯 ,5.5 省 时 开 作 录像 ，11 个 行业 项 目 开发 。10 个 各 
FR 多 9 开发 内 容 ( 靶 术 、 实例、 技巧 、 重 内、 项 目 、 界 而 

四 和 生得 词 方式 生动 开发 内 安 《 铺 肋 司 身 、 工 具 集 、 
ea | 


| 
图 4.24 添加 软件 产品 


在 add_soft.php 文件 中 ， 完 成 软件 产品 添加 表单 的 创建 ， 将 软件 产品 数据 提交 到 
up_modify softphp 文件 中 进行 处 理 。 软 件 产品 添加 表单 中 的 表单 元 素 如 表 4.9 所 示 。 
表 4.9 软件 产品 添加 表单 元 素 


在 up_modify softphp 文件 中 ， 获 取 表 单 提交 的 软件 产品 数据 ， 将 软件 及 软件 说 明 书 
iss 


名 称 | 元 素 类 型 重要 属性 含义 | 
i do action="up_modify_soft.php" method="post" 软件 产品 添加 | 
enctype="multipart/form-data" name="myform"> 表单 | 
name Text name="name" type="text" size="30" id="name" 软件 名 称 | 
<select name="resume" id="resume"> | 
<2php | 
do{ | 
?> ! 
Se Sele <option value=" <?php eho $info[mame']; ?>"> <?php 软件 类 别 
echo $info[mame']; ?></option> | 
<?php | 
}while($info=mysql_fetch_array($query)): | 
> | 
</select> | 
filesize text ="filesize" type="text" id="filesize" size="30" 软件 大 小 | 
fileimage text name="fileimage" type="file" id="fileimage" size="30" 软件 效果 图 | 
softdown file name="softdown" type="file" id="softdown" size="30" 上 传 软件 | 
softhtml file name="softhtml" type="file" id="softhtml" size="30" 软件 说 明 书 | 
die es eran name="introduce" cols="70" rows= 产品 描述 | 
id="introduce"></textarea> | 
es at name="submit" value=" 提 交 " < 提交 ”按钮 | 
onClick="return softsO:” | 
Submit2 Teset type="reset" name="Submit2" Value= “ 重 置 ”按钮 | 
i i pe button ne Sobmid2” Value=" 返 回 " < 返回 ”按钮 | 
‘onClick="Javascript:history.back(O:" | 
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存储 于 服务 器 指定 的 文件 夹 下 , 将 软件 相关 数据 存储 到 指定 的 数据 库 中 , 其 关键 代码 如 下 ; 
| 代码 位 置 ， 配 套 资源 \mr\04\up_modify_soft.php 


01 <?php 
02 ”header("Content-Type:text/html; charset=gb2312"); // 设 置 页 面 编码 格式 
03 include "../Conn/conn.php": // 包 含 数据 库 连 接 文件 
04 iflisset($ POST["submit"]){ // 判 断 提交 按钮 是 否 设置 
| 05 $name=$ POST['name']; 
| 06 Sresume=$ POST[resume]; 
| 07 $filesize=$_POST['filesize']: 
| 08 $introduce=$ POST[introduce]: /获取 表单 中 提交 的 数据 
| 09 S$uptime=date("Y-m-d"); 
| 10 if(!is_dir("../upload"){ // 判 断 upload 文件 夹 是 否 存在 
| 11 mkdir("../upload"); /如 果 不 存 在 ， 创 建 upload 文件 夹 
12 } 
13 if(!lis_dir("../soft") { // 判 断 soft 文件 夹 是 否 存在 
14 mkdir("../soft"); /如 果 不 存在 ， 创 建 soft 文件 夹 
15 } 
16 /上 传 图 片 
17 S$fileimage=$_ FILES['fileimage']['ame']; /获取 软件 图 片 名 称 
18 S$filepath="../upload/".$fileimage; // 定 义 软件 图 片 存储 路 径 
19 move_uploaded file($_FILES['fileimage']['tmp_name'],S$filepath):; 
// 完 成 软件 图 片上 传 操 作 
20 // 上 传 软件 资源 
2 Ssoftdown=$_FILES['softdown']['name']; // 获 取 上 传 软件 名 称 
22 Ssoftpath="../soft/".$softdown; // 定 义 软件 存储 路 径 
23 move_uploaded file($_FILES['softdown']["tmp_name"],$softpath); 
/执行 软件 上 传 操作 
24 /上 传 软件 说 明文 档 
25 $softhtml=$_FILES['softhtml']['name']: // 获 取 软 件 说 明 书 的 名 称 
26 $htmlpath="../soft/".$softhtml; // 定 义 软件 说 明 书 存储 位 置 
27 move_ Uploaded file($ softhtml" ne name"], Pen /上 传 软件 说 明 书 
28 inserti en esizeloa eimage,softdown,softhtml) 
| 29 values('$name','$uptime','$resume','$filesize',0. tr ,'$fileimage', 
| '$softdown','$softhtml)"; 
| 30 Sresult=mysql_query(Squery); /执行 软件 数据 添加 的 操作 
! 31 if($resul) { 
| 32 echo"<script>alert( 恭喜 您 ,软件 产品 添加 成 功 !):windowlocation href-'manage_ 
| soft.php';</script>"; 
| 33 jelsef 
| 34 echo"<script>alert( 对 不 起 ， 添 加 操作 失败 ! ):windowlocation .href- manage_ 
| soft.php':</script>"; 
| 35 } 
| 3 
| 37 > 


4.8.4 修改 软件 信息 实现 过 程 


当 用 户 单 击 “ 修 改 ” 超 链接 后 ， 将 进入 修改 软件 信息 页 面 ， 运 行 效果 如 图 4.25 所 示 。 
| I 


文件 大 小 Ee 证 意 : 弄 绩 和 文件 单位 [如 : KE、ME、G) 


上 传 图 片 广 意 : 支持 .gf 和 的 图 片 | 
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图 4.25 ”修改 软件 产品 信息 
在 update softphp 文件 中 ， 首 先 获 取 超 链 接 传递 的 ID 值 ， 然 后 根据 ID 值 从 数据 库 中 | 
查询 出 指定 的 数据 ， 并 且 将 数据 作为 修改 软件 产品 表单 中 元 素 的 默认 值 。 最 后 将 表单 中 的 | 
数据 提交 到 本 页 ， 在 本 页 中 完成 软件 产品 数据 的 更 新 操作 ， 其 关键 代码 如 下 : | 
代码 位 置 ， 配 套 资源 \mm\04\update_soft.php | 


01 <2php | 
02 S$soft idl=$_GET['soft id']; // 获 取 超 链接 传递 的 值 | 
03 iflisset($_POST['submit']){ // 判 断 更 新 按钮 是 否 设置 | 
04 $name=$_ POST[mame']; /获取 表单 提交 的 数据 
05 $resume=$ POST[resume']; 
06 Sfilesize=$ POST['filesize']: 
07 $introduce=$_POST['introduce']; 
08 S$uptime=date("Y-m-d"); 
09 S$sql=mysql_query("select * from soft where sfid="Ssoft_id1""); 

/根据 ID 值 从 数据 库 中 读 取 数据 
10 Sinfo=mysql_fetch_array($sqD; /获取 查询 结果 
11 /上 传 图 片 | 
12 这 $_FILES['file][mame'][0] 一 ""){ | 
13 $fileimage=$info['fileimage']; | 
14 }else{ | 
15 $fileimage=$ FILES[file][mame'][0]; | 
16 S$filepath="../upload/".$fileimage:; | 
17 move_uploaded file($ FILES['file'][tmp_name'][0].$filepathb): | 
18 } | 
19 /如 果 上 传 的 文件 为 空 ， 那 么 将 数据 库 中 的 值 赋 给 它 | 
20 // 上 传 软件 资源 | 
刘 if($_FILES['file' [name'][1]—"){ | 
22 $softdown=$info['softdown']; | 
23 }else{ | 
24 $softdown=$_FILES['file][mame][1]:; | 
25 $softpath="../soft/".$softdown: | 
26 Imove_ uploaded file($_FILES['file]['tmp_name'][1].$softpatb): | 
27 } | 
28 /上 传 软件 说 明文 档 | 
29 if($ FILES['file' [name'"][2]—""){ | 


sos 
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30 $softhtml=$info['softhtml"]: 

31 yelse{ 

32 $softhtml=-$ FILES[file][name'][2]: 

33 Shtmlpath="../soft/".$softhtml: 

34 move_uploaded file($ FILES['file][‘tmp name'][2],$htmlpath); 

35 } 

36 ift!is_dir("../upload") { // 判 断 upload 文件 夹 是 否 存在 

37 mkdir("../upload"); /如 果 不 存 在 ， 创 建 upload 文件 夹 

38 } 

39 if(!lis_dir("../soft"){ // 判 断 soft 文件 夹 是 否 存 在 

40 mkdir("../soft"); // 如 果 不 存在 ， 创 建 soft 文件 夹 

41 } 

42 Squery="update soft set namel13='S$name'uptime='$Suptime'resume='$resume'， 

43 filesize='Sfilesize',loadnum='Sloadnum',introduce='$introduce'", 

44 fileimage='Sfileimage',softdown='$softdown',softhtml='Ssofthtml' where 
sfid='$soft_idl'"; 

45 Sresult=mysql_query(Squery); // 执 行 数据 的 更 新 语句 

46 if($result) { 

47 echo"<script>alert(' 恭喜 您 ， 软 件 产品 修改 成 功 ! '");window.location.hre 伍 
‘manage_soft.php';</script>"; 

48 Jelse{ 

49 echo"<script>alert( 对不起， 修改 操 作 失 败 ! );windowlocationhre 合 
‘manage_soft.php';</script>"; 

50 } 

51 

52 > 


4.8.5 ”删除 软件 信息 实现 过 程 


当 用 户 单 击 “ 删 除 ” 超 链接 时 ， 将 跳 转 到 del_soft.php 文件 中 ， 根 据 超 链接 传递 的 ID 
值 ， 从 数据 表 中 删除 指定 的 记录 ， 其 关键 代码 如 下 : 
代码 位 置 ， 配 套 资源 \mr\04\del_soft.php 


01 <?php 

02 iheader("Content-Type:text/html; charset=gb2312"); // 设 置 页 面 编码 格式 

03 include "../Conn/conn.php"; // 连 接 数据 库 

04 S$soft idl=$_GETI['soft id']; // 获 取 超 级 链接 传递 的 ID 值 
05 Sdel sql="delete from soft where sfid='$Ssoft_idl'"; /定义 删除 语句 

06 igresult=mysql query($del sql): /执行 删除 语句 

07 这 $resulb{ 

08 echo "<script> alert( 删 除 成 功 !11"); windowlocation hre 人 manage_softphp':</script>"; 
09 }else{ 

10 echo "<script> alert(' 删 除 失败 111"); window.location .href "manage_soft.php';</script>"; 
mT 

| > 
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4.8.6 ”查询 软件 信息 实现 过 程 


用 户 在 软件 名 称 文本 框 中 输入 软件 名 称 后 ， 单 击 “ 查 询 ” 按 钮 ， 即 可 在 页 面 下 方 显示 
本 次 查询 结果 ， 其 运行 效果 如 图 4.26 所 示 。 | 


软件 产品 管理 
ait 
上 人 时 间 。 | 下 载重 人 | 
i | 
编程 司 幅 。 Javat 程 诬 2011-04-19 0 IEEJnES] 


图 4.26 查询 软件 信息 
在 manage_soft.php 文件 中 ， 首先 创建 查询 使 用 的 表单 ,将 数据 提交 到 本 页 。 其 关键 代 
人 码 如 下 : 
代码 位 置 ， 配 套 资源 \mr\04\manage_soft.php 


01 <form name="myform" method="post" action=""> 

02 <td colspan="4" align="center"> 请 输入 软件 名 称 : 

03 <input name="name" type="text" id="name"> 

04 <input type="submit" name="Submit" value=" 查 询 "> 
05 </td> 

06 </form> 


然后 ,在 manage_soft.php 文件 中 , 查询 数据 库 中 存储 的 所 有 软件 数据 ， 并 且 分 页 输出 
软件 数据 。 如 果 查 询 表单 提交 的 关键 字 存 在 ， 那 么 则 以 表单 提交 的 关键 字 为 条 件 ， 执 行 模 | 
糊 查 询 ， 查 询 出 符合 条 件 的 数据 ， 并 循环 输出 查询 结果 ， 其 关键 代码 如 下 : | 
代码 位 置 ， 配 套 资源 \mr\04\manage_soft.php 


01 <?php 
02 iffisset($_GET['"page'])){f // 判 断 分 页 变量 是 否 设置 | 
03 Spage= $_GET['page']; /为 分 页 变量 赋值 | 
04 Jelse{ | 
05 Spage=1; // 设 置 分 页 变量 初始 值 | 

06 } 

07 if($page){ ! 
08 Spage_size=10; // 定 义 每 页 显示 记录 数 | 
09 $query="select count(*) as total from soft order by sfid dese"; | 
// 定 义 SQL 语句 统计 总 记录 数 | 
10 $result=mysql_query($query): /执行 SQL 语句 | 
11 S$message_ count=mysql_result($result,0,"total"):; // 返 回 总 的 记录 数 | 
中 S$page_count=ceil($message_count/$page size); /计算 总 的 页 码 | 
13 Soffset=($page-1)*$page size; // 计 算 每 页 的 开始 位 置 | 
14 for($i=1; $i<2: SitD{ | 
15 if($i—1){ | 
16 if(isset($_POST['name']){ /如 果 提 交 的 关键 字 存在 | 
2 S$sql=mysql_query("select * from soft where name like '%".$_POST['name']."%""); | 
// 执 行 模糊 查询 | 
18 Jelse{ // 否 则 分 页 查询 所 有 记录 | 
*155°。 ‘ 


人 Pip 项 目 案 们 分 六 


| 2 
| 19 S$sql=mysql_query("select * from soft order by sfid desc limit 
| Soffset, Spage_size"); 
| 20 } 
2 Sresult=mysql_fetch_array($sqD); // 获 取 查 询 结 果 
2 } 
23 if($result){ // 如 果 结 果 为 真 
24 do{ // 循 环 输出 查询 结果 
25 人 
26 <tr> 
27 <td>&nbsp:<?php echo $result['resume']; ?></td> 
28 <td height="27">&nbsp;<?php echo $result[name']; ?></td> 
29 <td height="27">&nbsp;<?php echo $result['uptime']; ?></td> 
30 <td>&nbsp;<?php echo $result[loadnum']; ?></td> 
31 <td align="center"> 
32 <a href="update_soft.php?soft id=<?php echo $result['sfid'];?>"> 
33 <img src="../images/modify.gif" border="0"></a>&nbsp:&nbsp: 
34 <a href="del soft.php?soft id=<?php echo $result['sfid']:?>"> 
35 <img src="../images/del.gif" border="0"></a> 
36 <td> 
37 </tr> 
38 <2php 
39 }while($result-mysql fetch_array($sqD): 
40 j}else{ 
41 ?> 
42 <tr align="center"> 
43 <td height="27" colspan="7"> 暂 无 软件 产品 ! </td> 
44 </t> 
45 <?php 
46 } 
47 > 


注意 : 
| 由 于 后 台 管 理 系 统 中 的 功能 实现 大 同 小 异 ， 这 里 只 对 软件 产品 管理 进行 了 系统 的 讲 
| 解 ， 其 他 功能 的 实现 方法 这 里 不 再 讲解 ， 具 体内 容 请 参考 本 书 配套 资源 源码 。 


| 49 项 目 发 布 


1， 搭建 PHP 运行 环境 
| 于 笔者 在 开发 项 目 时 应 用 AppServ 集成 化 安装 包 搭 建 的 PHP 运行 环境 ， 所 以 建议 
| 读者 也 应 用 AppServ 来 搭建 PHP 运行 环境 。 这 样 可 以 确保 项 目 正 常 运行 。 
| 在 运行 本 项 目 时 , 建议 读者 将 php.ini 文件 中 错误 处 理 的 级 别 进行 调整 ,设置 级 别 如 下 : 
| error_ TIeporting=E_ALL& ~E NOTICE |E STRICT 
| 这 表示 显示 所 有 的 错误 ， 除 了 提醒 和 编码 标准 化 警告 。 
| 如 果 将 错误 处 理 设 置 为 如 下 级 别 : 
下 .156 。 
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error reporting =E_ ALL | 
那么 程序 在 运行 过 程 中 可 能 会 出 现 一 些 提醒 信息 和 编码 标准 化 警告 ， 导 致 程序 不 能 正 


2. 具体 项 目 发 布 方法 


发 布 本 项 目的 具体 方法 如 下 : 
(1) 将 程序 文件 夹 04 复制 到 AppServ 安装 后 的 www 文件 夹 下 。 | 
(2) 在 项 目 04 中 定位 到 data 目录 下 ， 复 制 db_mingri 数据 库 文件 夹 ， 将 其 存储 于 本 | 
机 MySQL 服务 器 安装 位 置 的 data 文件 夹 ( 如 AppServmysqlvdata) 下， 即 完成 数据 库 的 | 
附加 操作 ， 切 记 要 去 掉 数据 库 文件 的 只 读 属性 ， 否 则 不 能 对 数据 库 进行 添加 、 修 改 或 者 删 | 
除 操作 。 
(3) 如 果 要 向 服务 器 中 上 传 超大 文件 ， 那 么 必须 对 php ini 文件 中 的 某 些 内 容 进行 重 | 
新 配置 ， 具 体内 容 请 参考 4.8.2 节 。 | 
(4) 本 项 目 后 台 管 理 系统 的 登录 地 址 是 http://127.0.0.1/MR/04/admin/login.php， 登 录 | 
用 户 名 为 mr， 密码 为 mrsoft。 | 


本 章 小 结 


本 章 主要 讲解 企业 网 站 系统 的 实现 过 程 。 通 过 本 章 的 学 习 ， 读 者 可 以 对 企业 网 站 有 一 | 
个 更 深 的 了 解 及 印象 ， 并 且 能 够 熟练 掌握 以 下 技术 的 应 用 。 | 

(1) do...while 循环 语句 。 

(2) 通过 Dreamweaver 开发 工具 向 网 页 中 嵌入 Flash 动画 。 

(3) 通过 <img> 标 签 输出 图 片 。 

(4) 数字 验证 码 的 生成 。 

(5) 文字 、 图 片 滚动 特效 。 

(6) 文件 上 传 技术 。 
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明日 网 上 书店 


( PHP+Smarty+ADODB+MySQL 实现 ) 
合 m 自学 视频 、 源 程序 : 配套 资源 \mr\S\ 


随 着 Internet 的 发 展 ， 电 子 商务 将 成 为 21 世纪 网 络 发 展 的 主流 ， 网 上 购物 
也 将 成 为 一 种 新 的 时 尚 。 目 前 国内 企业 正 纷 纷 加 入 阿里 巴巴 等 一 系列 大 型 电子 
商务 网 站 的 阵营 中 。 随 着 网 络 B2B (企业 对 企业 ) 交易 的 普及 ， 各 大 企业 也 充 
分 意识 到 网 络 交易 将 成 为 未 来 商品 交易 的 重要 组 成 部 分 ， 在 建立 企业 宣传 网 络 
的 同时 ， 也 需要 逐步 扩大 企业 自身 的 网 络 销售 范围 ， 以 企业 自己 的 电子 商务 网 
站 为 媒介 ， 开辟 更 广阔 的 市 场 ， 来 实现 从 B2B 到 B2C (企业 对 个 人 ) 网 络 交易 
同步 的 过 渡 ， 这 样 才 能 大 大 提高 企业 的 经 济 效 益 。 随 着 硬件 技术 和 网 络 技 术 的 
发 展 ， 以 及 网 上 交易 法 规 的 日 趋 完 善 ， 电 子 商务 将 成 为 企业 销售 经 营 的 主要 渠 
道 之 一 。 

通过 阅读 本 章 ， 读 者 可 以 学 到 : 


了 ”如何 设计 网 站 结构 

MH ADODB 操作 MySQL 数据 库 

PH ”Smarty 模板 完成 网 站 动静 分 离 

剖面 向 对 象 技术 的 实际 运用 ( 教 据 库 连 接 、 操 作 类 、 购 物 车 类 、 分 页 类 ) 
了 FckEditor 在 线 编辑 器 的 运用 

WI PHP 伪 静 态 技 术 的 应 用 
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5.1 功能 设计 思路 


5.1.1 功能 阐述 


吉林 省 明日 科技 有 限 公司 是 一 家 以 互联 网 经 营 为 主 的 高 科技 企业 , 在 多 年 的 互联 网 经 
营 中 ， 总 结 和 积累 了 大 量 互联 网 营销 经 验 。 在 精神 文明 高 速 发 展 的 今天 ， 图 书 已 经 成 为 人 | 


们 增长 知识 和 提高 能 力 的 重要 工具 之 一 ， 以 往 读者 需要 到 书店 购买 图 书 ， 这 样 需 要 花费 很 
多 时 间 ， 而 网 上 购书 只 需 利 用 茶余饭后 的 时 间 就 可 以 实现 ， 给 购书 者 带 来 了 极 大 方便 。 综 
合 上 述 原 因 ， 该 企业 决定 投资 网 上 书店 项 目 ， 并 通过 两 年 时 间 将 该 网 上 书店 打造 成 为 国内 
知名 的 电子 商务 类 网 站 。 

通过 实际 调查 ， 明 日 网 上 书店 网 站 应 该 具备 以 下 功能 : 


回 明确 的 图 书 分 类 模块 
回 ”稳定 的 购物 车 模块 
回 ”安全 的 在 线 支 付 模块 
回 人 性 化 的 图 书信 息 分 页 展示 模块 
回 高 效 的 图 书信 息 查 询 模块 
回 ”便捷 的 后 台 管 理 模块 
明日 网 上 书店 的 业务 流程 如 图 5.1 所 示 。 
EE 
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图 5.1 明日 网 上 书店 业务 流程 图 
“159. 


5.1.2 ”系统 预览 
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图 5.2 明日 网 上 书店 首页 主体 部 分 界面 


试 读 图 书展 示 页 面 运行 效果 如 图 5.3 所 示 。 
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rT Te 划 ， 打 量程 交 、 疡 站 
nN 


和 人 


图 5.3 试 读 图 书展 示 页 面 


“0 


避 店 管理 系统 由 多 个 页 面 组 成 ， 下 面 仅 列 出 几 个 典型 页 面 ， 其 他 页 面 请 
配套 资源 中 的 源 程序 。 
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购物 车 页 面 运行 效果 如 图 5.4 所 示 。 


病 风物 这 吾 


5.4 ”购物 车 页 面 


迅 


图 5.5 后 台 管理 页 面 


5.1.3 ”功能 结构 


为 了 能 够 使 读者 更 清楚 地 了 解 明日 网 上 书店 网 站 的 结构 ， 下 面 给 出 该 网 站 的 前 台 功 能 | 


模块 结构 图 和 后 台 功 能 模块 结构 图 。 
明日 网 上 书店 网 站 前 台 管理 系统 的 功能 设计 如 图 5.6 所 示 。 


明日 网 上 书店 前 台 管 理 系 统 | ---------------------- 


由 必 
的 


新 | | 特 | | 热 器 | | 本 | | 用 | | 斌 
书 | | 从 | | 卖 网 | | 站 | | 户 || 讯 
推 | | 图 | | 本 办 | | 会 | | 答 || 
厦 | | 书 | | 书 扳 | | 告 | | 录 || 牧 


闻 坟 > 疗 当 棕 


图 5.6 网 站 前 台 功 能 结构 图 
“Os 


-- 带 格式 的 : 字体 : 8 磅 


gm 人 ie 项 目 业 例 分 析 


明日 网 上 书店 网 站 后 台 功 能 结构 图 如 图 5.7 所 示 。 


明日 网 上 书店 后 台 管理 系统 _ | a 
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滔 碍 凉 当世 
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县 
设 
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[rt ] [到 人 管理 


畅 | | 图 
销 | | 书 
书 | | 春 
讯 || 行 
管 | | 管 
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图 5.7 网 站 后 台 功 能 结构 图 
5.1.4 文件 组 织 结构 
PHP 语言 在 5.0 以 后 的 版 本 中 ， 面 向 对 象 编 程 已 经 相对 完善 、 成 熟 ， 用 户 数量 也 在 飞 
速 增多 。 在 PHP 发 展 过 程 中 ， 很 多 公司 都 推出 了 简化 PHP 开发 的 模板 或 类 库 ， 其 中 较为 


典型 的 有 Smarty 模板 引擎 技术 、ADODB 数据 抽象 层 接口 等 。 使 用 Smarty 模板 引擎 技术 
可 以 使 业务 逻辑 的 实现 与 视图 的 实现 分 离开 来 ， 使 用 ADODB 可 以 高 效 、 稳 定 地 对 数据 库 


进行 管理 ， 如 果 将 二 者 同时 运用 于 项 目 ， 就 可 以 实现 MVC 开发 模式 。 
综 上 考虑 ， 本 项 目 决定 采用 Smarty 模板 引擎 和 ADODB 数据 库 抽象 层 类 库 相 结合 的 
方式 进行 整合 开发 ， 并 最 终 规划 出 明日 网 上 书店 主要 目录 及 文件 的 架构 ， 如 图 5.8 所 示 。 
区 中 网 站 根 目录 
© eofo 系统 配置 廊 件 目录 
HS es Css 样 式 文件 目录 
由 全 mg 图 片 目录 
全 先生 js 朋 本 文件 目录 
ee 工程 类 库 文件 目录 
区 adodh ADopE 贡 库 
由 局 fckedtor FciEditor 类 库 
BB smarty Saarty 交 库 
5 AdminDB php 涩 需 库 芝 理 尖 
由 - 回 Cattphp 购物 车 关 
9 回 compephp 下 用 库 连接 区 
四 回 Makestatcpage php 前 老 页 面 生成 区 
由 @ pageDe pho 分 页 类 
国 加 SmartyConfigphp 一 一 一 一 一 一 一 一 一 一 一 一 一 sawrty 模 板 引 元 有 置 类 
由 加 ulphp 工具 类 
BE upfies 上 传 文件 保存 目录 
人 vows Searty 模 板 视图 保存 目录 


图 5.8 明日 网 上 书店 文件 架构 图 
。162 。 


__-- 巧 带 格式 的 : 字体 : 8 磅 
a 带 格式 的 : 字体 : 8 磅 
“、、【 带 格 式 的 : 字体 : 8 磅 
、\ 带 格式 的 : 字体 : 8 磅 

带 格式 的 : 字体 : 8 磅 


__--【 带 格 式 的 : 字体 : 8 磅 
“-[ 带 格 式 的 : 字体 : 8 磅 
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5.2 ”数据库 设计 


明日 网 上 书店 是 一 个 基于 数据 库 开发 的 应 用 程序 。 本 节 针 对 明日 网 上 书店 网 站 的 数据 | 


库 设 计 进 行 详 纪 


介绍 。 由 于 数据 库 是 网 站 内 容 的 主要 载体 ， 所 以 设计 出 合理 的 数据 库 表 及 | 


表 间 关系 非常 重要 。 
5.2.1 数据 库 设 计 结 构 


明日 网 上 书店 的 数据 库 db_bookshop 包含 的 主要 数据 表 有 也 _bigtype( 图 书 大 类 别 表 )、 


tb_smalltype (图 书 小 类 表 )、 tb_bookinfo (图 书信 息 表 )、tb_cxsx (畅销 书 讯 表 )、 tb feedback | 


(用 户 反馈 表 )、tb_mrbookph (图 书 排行 表 )、tb_pl (评论 表 )、tb_pub 〈 出 版 社 信息 表 )、 
tb_read〔 试 读 下 载 信息 表 )、tb_order (订单 表 )、tb_tell (公告 表 )、tb_system (系统 信息 


表 ) 和 tb_user (用 户 信息 表 )， 如 图 5.9 所 示 。 


图 服务 器 -bcahost ， 尿 数据 库 : gb_bookshop 


要 所作 记 寻 数 ” 类 于 村民 
由 boype 国 辐 因 革 便 Xx 2 NytSAM gb2312_chinese_ oi 
中 bookinf 站 加 x 了 NyISAM gh2312 chinese dl 
wax 国 四 因 革 全 XX WiSAM gh2312 chinese al 
中 leetbeck 羡 呵 辐 关 许 X 2 MySAM gb2912_chinese 9 
中 mbookph 国耻 同年 XX BS MyrSAM yb2312_chinese_ ci 
th_order 国 甸 加 美音 X MyISAN gb2312 chinese cl 
pl 国 林 罗 芋 国 X MyiSAM gb2312 chinese ol 
th_pub 国 上 四 轩 革 时 XxX 6 MYISAN gb2312_chinese_ cl 
hb_rmad 加 只 加 半 X 5 MytSAM gh?2312_chinese ci 
msmiype 国 贞 因 半 和 $3 NytSAM gb2312_chnese. ol 
arm 国 四 辐 革 全 XX Y MytSAM gb2312 chinese oi 
ball 国 丁 四 革 里 xX BMySAM gb2312_chinese_o 
由 user 国 厅 加 闫 下 X I NyISAM gb2312 chinese oi 


图 5.9 明日 网 上 书店 数据 库 结构 


5.2.2 ”数据 表 设计 结构 
明日 网 上 书店 网 站 数据 库 中 主要 数据 表 的 设计 结构 如 表 5.1 一 表 5.5 所 示 。 


表 5.1 tb_bigtype 表 


说 明 
图 大 而 表 
图 书信 息 表 
剧 什 书 夺 表 
用 户 反 馆 表 
图 书 排行 表 
订单 表 
评论 表 
出 版 社 信息 才 
试 该 下载 信息 胡 


数据 类 型 字段 大 小 说 明 
[am | un | 3# 键 | 


int 


自动 增长 
大 类 名 称 


varchar 50 
datetime 


表 5.2 tb_smalltype 表 


添加 时 间 


是 否 主 键 说 了 明 


主键 自动 增长 


大 类 名 称 


添加 时 间 


63s 


外 键 ， 大 类 ID 


人 Pytp 项 目 业 便 分 析 


2 
表 5.3 tb_bookinfo 表 
字段 名 称 数据 类 型 字段 大 小 是 否 主 键 说 了 明 
id int 11 主键 自动 增长 
bookname varchar 50 大 类 名 称 
smalltypeid datetime 添加 时 间 
oldprice float 图 书 原价 
newprice float 本 站 价格 
bookimg varchar 100 一 一 一 图 书 封面 图 片 名 称 
isnew bool 是 否 新 书 
addtime datetime 一 一 一 添加 时 间 
about text 图 书 介 绍 
issepprice bool 是 否 特价 图 书 
browsertime int 11 浏览 次 数 
ismrbooktj bool 是 否 明日 科技 创作 
pubid int 11 出 版 社 ID 
Writer Varchar 50 作者 
pubtime date 出 版 时 间 
ishave bool 是 否 有 货 
bedse int | ”| 图 书 层次 标识 
page int 4 | | 图 书页 码 
isbn varchar 20 | | 图 书 ISBN 号 
Zs int 4 | | 图 书 字数 
bc Varchar 50 | | 图 书 版 权 
directoi text | | 图 书目 录 
bookids varchar 100 | | 关联 图 书 ID 所 组 成 的 字符 串 
ishotsell bool | | 是否 热卖 图 书 
isterm bool | | 是 否 期 书 
表 5.4 tb_order 表 
字段 名 称 数据 类 型 字段 大 小 说 了 明 
id int 11 自动 增长 
orderno varchar 50 大 类 名 称 
orderusernc varchar 50 订购 用 户 昵 称 
Username varchar 50 订购 人 姓名 
address varchar 250 订购 人 联系 地 址 
SeX Varchar 4 订购 人 性 别 
b varchar 10 订购 人 邮编 
tel Varchar 20 订购 人 联系 电话 
tt varchar 50 发 票 抬头 
idstr varchar 100 订购 图 书 ID 组 成 字符 串 
numstr Varchar 100 订购 图 书 数量 组 成 字符 串 


字段 名 称 


goodsprice float 


price float 


paytype varchar 支付 方式 
addtime datetime 订购 时 间 
isk bool 是 否 付款 


bool 
issh bool 


是 否 发 货 
是 否 收 货 


表 5.5 tb_user 表 


是 否 被 用 户 取消 订购 


字段 名 称 | 数据 类 型 | 字段 大 小 | 是 否 主键 | 说 了 明 
i int 11 自动 增长 
Userne varchar 50 [| 用 户 昵称 
truename varchar 50 | | 真实 姓名 
pwd Varchar 50 | | 登录 密码 
email varchar 50 | | E-mail 地 址 
SeX char 入 | | 性 别 
tel varchar 20 | | 联系 电话 
varchar 20 | | kos 
address Varchar 100 [| 联系 地 址 
logintimes int 8 | | 登录 次 数 
Tegtime datetime [il 注册 时 间 
lastlogintime datetime | | 最 后 登录 时 间 
让 Varchar 20 | | 注册 时 人 P 地 址 
b varchar 20 | | 邮政 编码 
usertype tinyint 1 | | 用 户 类 别 标识 
question Varchar 200 | | 密码 找 回 问题 
answer varchar 200 | | 密码 找 回答 案 
truepwd varchar 200 -一 -一 真实 密码 
photo Varchar 50 头像 


代码 重用 率 高 是 面向 对 象 编程 的 特点 之 一 ， 应 用 面向 对 象 编程 可 以 有 效 地 提高 项 目的 
开发 效率 和 可 维护 性 。 在 以 往 面向 过 程 的 编程 方式 中 ， 程 序 员 为 了 实现 类 似 的 功能 ， 往 往 
需要 在 每 个 使 用 该 功能 的 模块 中 重复 输入 相同 的 代码 ， 这 样 就 使 开发 人 员 浪 费 了 很 多 时 


5.3 ”公共 类 设计 


“0 


人 Bi 项 目 业 例 分 析 


司 ， 而 应 用 面向 对 象 的 编程 方式 ， 只 需 将 功能 相同 的 代码 封装 成 类 ， 然 后 在 每 次 需要 使 用 
| 该 类 的 位 置 调用 该 类 的 相应 方法 即 可 ， 如 果 该 功能 需要 改动 ， 只 需 改动 该 类 中 某 个 方法 即 
可 。 在 制作 明日 网 上 书店 之 前 ， 为 了 避免 过 多 重复 代码 的 出 现 ， 笔 者 最 终 决 定 将 该 项 目的 
主要 功能 封装 成 多 种 应 用 类 ， 这 些 类 分 别 是 数据 库 连接 类 、 数 据 库 管理 类 、Smarty 模板 配 
”| 置 类 、 购 物 车 类 、 分 页 类 和 工具 类 等 几 个 公共 类 模块 。 下 面 对 封装 的 这 些 类 进行 介绍 。 
ote 
5.3.1 数据库 连 接 类 


| 明日 网 上 书店 的 数据 库 管理 采用 的 是 ADODB 数据 库 抽象 层 技术 , 使 用 ADODB 技术 
| 连接 数据 库 ， 可 以 实现 对 多 种 数据 库 进行 连接 。 本 项 目 所 建立 的 数据 库 连接 类 可 以 实现 对 
| MySQL、SQL Server 和 Access 的 连接 ， 是 一 个 扩展 能 力 较 强 的 数据 库 连接 类 ， 其 具体 实 
| 现 方式 如 下 。 

| (1) 定义 数据 库 连 接 类 的 属性 ， 该 类 存储 于 library 文件 目录 下 的 ConnDB.php 文件 
| 中 ， 其 关键 代码 如 下 ; 

| 代码 位 置 ， 配套 资源 \mr\05\library\ConnDB.php 


01 var$dbType: /| 数据 库 类 型 标识 

02 var $host; /| 数据 库 服 务 器 地 址 
03 var $userName: /数据 库 服务 器 用 户 名 
04 var$password: // 数 据 库 用 户 密码 

05 var$dbName:; // 要 连接 的 数据 库 名 
06 var S$isDebug: // 是 否 显示 调试 信息 
07 var $connID: /数据 库 连接 IJD 


| 
| 
| 
| 
| 
| 

说明: 

”这 里 为 了 兼容 PHP 5.0 以 下 的 版 本 ， 所 有 属性 都 定义 成 var 型 。 
| 

| (2) 定义 数据 库 连接 类 的 构造 方法 ， 实 现 对 类 内 属性 的 初始 化 ， 其 关键 代码 如 下 : 
| 

| 代码 位 置 : 配套 资源 \mr\05\library\ConnDB.php 

| 01 function ConnDB ($dbType = "mysql, $host, SuserName. $password, $dbName, $isDebug = false){ 
| 

| 

| 


| 02 Sthis->dbType = $dbType: // 为 数据 库 类 型 赋 初 值 
| 03 S$this->host = $host: /为 服务 器 地 址 赋 初 值 
| 04 S$this->userName = $userName: /为 用 户 名 赋 初 值 

| 05 $this->password = $password: // 为 密码 赋 初 值 

| 06 Sthis->dbName = $dbName: // 为 数据 库 名 赋 初 值 

| 07 Sthis->isDebug = SisDebug: // 为 调试 信息 赋 初 值 

| 08 } 


说 明 : 


上 述 代 码 中 的 “->” 是 PHP 面向 对 象 编程 方式 中 ， 实 例 化 的 对 象 引 用 类 中 方法 或 属性 


的 标识 符 。 


ss 
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SL | 
(3) 通过 ConnDBO 构 造 方法 对 类 中 属性 初始 化 后 ， 就 可 以 实现 与 数据 库 的 连接 。 具 | 

体 连接 过 程 通过 方法 getConnIDO 实 现 , 在 该 方法 中 根据 属性 $dbType 的 值 来 判断 要 连接 数 | 

据 库 的 类 型 ， 并 根据 不 同 的 数据 库 类 型 选择 相应 的 数据 库 连 接 驱 动 ， 最 终 返回 连接 对 象 ， | 

其 关键 代码 如 下 : 
代码 位 置 : 配套 资 源 \mr\05\library\ConnDB.php | 


MNote 
01 function getConnID Of | 
02 Tequire_once(library/adodb/adodb.inc.php7: // 导 入 ADODB 类 库 | 
03 Sthis->connID =NewADOConnection(Sthis->dbType): /生成 数据 库 连接 对 象 | 
04 让 (Sthis->dbType 一 mysql | Sthis->dbType 一 mssql) { // 如 果 为 MySQL 数据 库 或 者 | 
SQL Server 数据 库 | 
05 S$this->connID->Connect($this->host, $this->userName, $this->password., $this->dbName); | 
// 通 过 Connect0 方 法 建立 与 数据 库 的 连接 | 
06 if (Sthis->dbType 一 mysql { | 
07 ©@ Sthis->connID->Execute('set names gb2312): /设置 数据 库 编码 | 
08 } | 
09 } elseif (Sthis->dbType — 'access’) { // 如 果 为 ACCESS 数据 库 | 
10 $this->connID->Connect(Driver = {Microsoft Access Driver (*.mdb)}; Dbq = . | 
realpath($this->dbName) . | 
11 "Uid=". $this->userName . ‘Pwd =" . $this->password . ';"); | 
12 yelse { | 
13 Teturn false: | 
14 } | 
15 S$this->connID->debug = $this->isDebug: /是否 调试 | 
16 retum $this->connID: /返回 数据 库 连接 对 象 | 
> | 
Ah 关键 代码 解析 


@ Execute( 方 法 用 来 执行 SQL 语句 ， 这 里 的 set names gb2312 是 用 来 设置 数据 库 的 编码 为 gb2312 编码 。 


上 述 代码 首先 使 用 require_once0 函 数 包含 ADODB 中 的 adodb.inc.php 文件 , 这样 就 实 
现 了 将 ADODB 类 库 包含 到 工程 中 , 然后 根据 属性 $dbType 的 值 判断 要 连接 数据 库 的 类 型 ， 
再 根据 不 同 的 数据 库 类 型 选择 不 同 的 连接 方式 ,最 后 通过 returm 语句 返回 数据 库 连 接 对 象 ，| 
在 进一步 开发 中 ， 只 需 通过 该 方法 返回 的 数据 库 连接 对 象 来 调用 相应 的 方法 (如 Execute0 | 

方法 ) 即 可 实现 对 数据 库 的 查询 。 
(4) 完成 对 数据 库 的 操作 后 ， 还 需要 关闭 对 数据 库 的 连接 ， 这 里 通过 closeConnIDO 

方法 实现 ， 其 实现 代码 如 下 : 

function closeConnID Of{ | 
@$this->connID->DisconnectO: /关闭 与 数据 库 的 连接 


说 明 : 
在 开发 PHP 项 目 时 ， 可 以 通过 在 语句 前 加 “@” 来 屏蔽 运行 时 错误 。 


。167 。 SH 
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以 上 为 数据 库 连接 类 ConnDB 的 全 部 核心 内 容 ， 主 要 实现 对 不 同类 型 数据 库 的 连接 及 

| 在 操作 完 数据 库 后 释放 资源 等 操作 。 

| 

人 5.3.2 数据 库 管理 类 

傅 - | 

| 为 了 对 项 目 中 的 SQL 语句 进行 统一 管理 ， 提 高 代码 重用 率 和 项 目的 可 维护 性 ， 这 里 
性 2 一 将 数据 库 的 增 、 出 、 改 、 查 操作 通过 名 为 AdminDB 的 数据 库 管理 类 实现 ， 该 类 中 只 有 一 

| 个 名 为 executeSQLO 的 方法 ， 通 过 该 方法 可 以 实现 对 数据 库 的 所 有 查询 和 维护 操作 ， 其 中 
AdminDB.php 文件 的 关键 代码 如 下 : 

| 代码 位 置 ， 配套 资源 \mr\05\ibraryAdminDB.php 


01 class AdminDB 


D2 

| 03 function executeSQL ($sql, $connID) 

| 04 

| 0 ©@ $sqlType = strtolower(substr(trim($sql). 0. 6): // 提 取 SQL 语句 的 类 型 
06 S$rs = $connID->Execute($sql): /执行 SQL 语句 

| 07 if ($sqlType — 'select'’) { // 如 果 是 select 查询 

| 0 ©@ SarrayData = $rs->GetRows(): // 返 回 查询 记录 集 

| 09 if (count($arrayData) — 0 || $rs 一 false) { // 如 果 没 查询 到 或 发 生 错 误 

| 10 Tetum false: // 返 回 false 

| 而 } else{ /否则 

| 2 return $arrayData; // 返 回 记 录 集 

| 13 } 

| 14 } elseif ($sqlType 一 ‘insert || $sqlType 一 "pdate || $sqlType =— 'delete’) { 

| 15 /如 果 执 行 插入 、 更 新 或 删除 语句 

| 16 return Srs; // 返 回 语句 执行 状态 ， 即 成 功 返回 tme， 失 败 返 回 false 

| 17 } else { 

| 18 return false; // 如 果 不 是 上 述 查 询 ， 则 返回 false 

| 19 } 

| 20 ! 

| 2 

| 

| < 关键 代码 解析 

| 


@ 函数 strtolower0 〇 用 来 将 字符 囊 中 所 有 字符 转换 为 小 写 ， 这 里 将 SQL 语句 全 部 转换 为 小 写 ， 是 为 
| 了 在 判断 语句 类 型 时 忽略 SQL 语句 的 大 小 写 。 

| @ GetRows() 方 法 用 来 获取 查询 记录 集 ， 并 将 结果 保存 到 二 维 数组 中 ， 其 中 第 一 维 为 记录 索引 ， 第 二 
| 维 为 表 字段 名 。 

| 上 述 数据 库 管 理 类 中 的 executeSQL0O 方 法 包含 $sql 和 $connID 两 个 参数 ， 分 别 为 要 执 
| 行 的 SQL 语句 和 数据 库 连接 对 象 。 在 函数 体内 ， 首 先 将 传 入 的 SQL 语句 转换 成 小 写 ， 然 
| 后 提取 SQL 语句 的 前 6 个 字符 ,同时 通过 数据 库 连接 对 象 的 Execute0 方 法 执行 SQL 语句 ， 
| 并 根据 提取 SQL 语句 的 前 6 个 字符 判断 SQL 语句 类 型 ， 从 而 返回 查询 结果 。 
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说 明 : 
上 述 代码 之 所 以 要 提取 SQL 语句 的 前 6 个 字符 ， 是 因为 select、update 和 delete 这 3 
个 关键 字 的 特点 是 长 度 均 为 6 个 字符 。 


5.3.3 Smarty 模板 引擎 配置 类 


Smarty 是 PHP 的 模板 引擎 。 通 过 Smarty 可 以 使 程序 开发 人 员 和 美工 人 员 互 不 影响 地 
完成 各 自 的 工作 ， 在 项 目 开 发 中 ， 后 台 编 码 和 前 台 设 计 可 以 同步 进行 。 在 对 项 目 进行 维护 
过 程 中 ， 页 面 更 改 不 会 影响 业务 逻辑 的 实现 。 同 时 ，Smarty 模板 增加 了 视图 缓存 和 静态 页 
面 生成 机 制 ， 从 而 可 以 有 效 提 高 项 目的 执行 效率 。 使 用 Smarty 时 需要 对 环境 进行 配置 ， 
为 了 简化 配置 、 提 高 项 目的 可 扩展 性 ， 在 开发 明日 网 上 书店 网 站 时 ， 将 对 Smarty 模板 的 
配置 单独 封装 成 SmartyConfig 类 ， 其 实现 代码 如 下 : 

代码 位 置 : 配套 资源 \mr\05\library\SmartyConfig.php 


01 require once('library/smarty/libs/Smarty.class.php): // 包 含 Smarty.class.php 文件 ， 
从 而 导入 Smarty 类 库 

02 ”class SmartyConfig extends Smarty { /编写 SmartyConfig 类 ， 使 其 继承 自 Smarty 类 

03 function SmartyConfig O{ // 构 造 方法 

04 S$this->SmartyO: // 调 用 父 类 的 构造 方法 

05 © $arrayIni = parse_ini file('‘config/lzhConfig.ini”); /解析 LzhConfig.ini 文件 ， 来 
获取 配置 信息 

06 S$this->template_dir = $arrayIni[template_dir]: /模板 文件 保存 目录 

07 Sthis->compile_dir = $arrayImi['compile_dir]: /编译 文件 保存 目录 

08 Sthis->cache_dir = $arrayIni['cache_dir]: /缓存 文件 保存 目录 

09 S$this->config dir = $arrayIni['config dir]; // 配 置 文 件 保存 目录 

10 Sthis->caching = $arrayIni['caching']: // 是 否 开启 视图 缓存 

11 } 

12 } 
Ah 关键 代码 解析 


@ 函数 parse ini file0 用 来 解析 .ini 文件 ， 并 将 解析 结果 保存 在 数组 中 。 


上 述 代码 ， 首 先 通过 函数 require_ onceO 包 含 Smarty 类 库 中 的 Smarty.class php 文件 ， 从 
而 将 Smarty 类 库 导 入 到 工程 中 ， 然 后 定义 SmartyConfig 类 ， 使 之 继承 自 Smarty 类 ， 在 该 类 
的 构造 方法 中 ， 首 先 通过 $this 关键 字 调 用 父 类 的 构造 方法 ， 从 而 实现 对 Smarty 模板 引擎 的 
初始 化 ， 然 后 使 用 $this 关键 字 分 别 调用 Smarty 模板 中 的 属性 来 对 模板 路 径 进 行 配置 。 


5.3.4 ”购物 车 类 


对 于 电子 商务 类 网 站 来 说 ， 安 全 、 稳 定 的 购物 车 模块 是 非常 重要 的 ， 该 模块 直接 关系 
到 交易 是 否 能 够 顺利 进行 。 为 了 提高 代码 的 可 移植 性 ， 在 制作 明日 网 上 书店 购物 车 时 ， 通 
过 将 购物 车 抽象 成 类 来 实现 ， 下 面具 体 介 绍 该 购物 车 类 的 实现 方法 。 


(1) 在 library 文件 目录 下 创建 购物 车 封装 文件 Cartphp。 定 义 购物 车 类 的 属性 $idstr | 
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| 和 Snumstn 分 别 用 来 表示 购物 车 中 存放 商品 的 ID 字符 下 和 数量 字符 下 ,并 分 别 用 字符 “@” 
”进行 连接 ， 代 码 如 下 : 


| Var $idStr: /商品 芽 组 成 的 字符 串 ， 用 字符 @ 进 行 连接 
全 站 | var $numStr; // 商 品 数量 组 成 的 字符 串 ， 用 字符 @ 进 行 连接 


(2) 定义 购物 车 类 的 构造 方法 ， 用 来 对 商品 人 D 串 和 商品 数量 串 赋 初 值 ， 实 现代 码 如 下 : 
代码 位 置 ， 配套 资源 \mr\05\library\Cart.php 
01 function Cart($idStr SnumSstnD{ 


02 S$this->idStr = $idStr: // 为 D 串 赋 初 值 
| 03 Sthis->numStr = $numStr: // 为 数量 串 赋 初 值 
| 04 1} 


(3) 将 商品 添加 到 购物 车 是 通过 addCart0 方 法 实现 的 ， 其 关键 代码 如 下 : 
代码 位 置 ， 配套 资源 \mr\05\library\Cart.php 
01 function addCart($goodsId, $goodsNum){ 


02 ®@ SarrayIds=explode(@'. $this->idStr); // 将 D 串 用 “@” 分 割 ， 并 将 分 割 结果 
| 保存 到 数组 中 
| 03 Sflag = 0: /商品 是 否 添加 标识 
| 04 for($i=0; $i <count($arrayIds): $i++){ // 判 断 商 品 是 否 已 经 在 购物 车 中 
| 05 if($arrayIds[$i] 一 $goodsId){ // 如 果 该 商品 在 购物 车 中 ， 则 使 $flag 的 值 为 1 
| 06 Sflag = 1: 
| 07 } 
| 08 } 
| 09 if($flag — 0){ /如 果 $flag 的 值 为 0， 则 说 明 该 商品 不 在 购物 车 中 
| 10 Sthis->idStr .= $goodsId . '@'; // 连 接 新 增 的 商品 ID 
| 11 Sthis->numStr = $goodsNum .,@': /| 连接 新 增 的 商品 数量 
| 12 }else{ 
| 13 echo "<script>alert( 该 商品 已 经 添加 ! ):</script>"; 。 ”// 如 果 该 商品 已 经 在 购 
| 物 车 中 ， 则 给 出 提示 
| 14 } 
| 1 
| < 关键 代码 解析 


| 

@ 函数 explodeO 用 于 将 字符 串 用 指定 的 子囊 分 割 ， 并 将 分 割 结果 保存 到 数组 中 。 

上 述 的 addCart0 方 法 包含 ggoodsId 和 $goodsNum 两 个 参数 ， 分 别 用 于 表示 新 增 商品 的 
ID 和 数量 。 在 该 方法 内 部 ， 首 先 通过 for 循环 语句 遍历 购物 车 中 已 经 存在 商品 的 ID， 如 果 
| 用 户 向 购物 车 中 新 添加 的 某 种 商品 的 ID 已 经 存在 于 购物 车 中 ， 则 会 给 出 该 商品 已 经 在 购物 
| 车 中 的 提示 信息 ; 否则 ,将 该 商品 ID 以 及 购买 数量 分 别 连接 到 购物 车 类 的 ID 串 和 数量 串 中 。 
(4) 将 商品 移出 购物 车 是 通过 remove0 方 法 实现 的 ， 代 码 如 下 : 

代码 位 置 配套 资源 \mr\05\library\Cart.php 


01 function removeCart($goodsId){ 
02 S$arraylds = explode(@'. $this->idStr): // 将 商品 ID 串 用 “@” 分 割 成 数组 
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03 SarrayNums = explode('@ Sthis->numst: // 将 商品 数量 串 用 “@” 分割 成 数组 | 
04 for($i= 0: $i < count($arrayIds): Si++){ // 遍 历 商品 攻 串 | 
05 于 ($arrayIds[$i] 一 $goodsId){ /如 果 查 找到 与 要 删除 商品 ID 相同 的 数组 元 素 ， 
06 © unset(SarrayIds[Si]): // 则 删除 该 元 素 | 
07 unset($arrayNums[$i]): // 同 时 删除 该 商品 的 数量 | 
08 } | 
09 } 
10 Sthis->idStr = implode('@', $arrayIds); /重新 将 商品 ID 和 数量 数组 连接 成 字符 串 
11 S$this->numStr = implode('@', $arrayNums); | 
12 | 
1 


< 关键 代码 解析 | 

@ 函数 unsetO 用 于 销毁 指定 的 变量 ， 当 然 也 可 以 是 数组 元 素 。 | 

removeCart0 方 法 中 只 有 $goodsId 一 个 参数 ， 用 于 表示 要 移 除 商品 的 人 D 号 ， 在 该 方法 | 
内 部 ， 首 先 将 商品 ID 串 用 字符 “@” 分 割 ， 并 将 分 割 结果 保存 到 数组 中 ， 然 后 通过 for 循 | 
环 语句 遍历 该 数组 ,如果 在 该 数组 中 查找 到 与 要 删除 商品 号 码 相同 的 功 , 则 使 用 函数 unset0 | 
将 该 数组 元 素 销毁 ， 然 后 再 将 该 数组 所 有 元 素 重 新 用 字符 “@” 连 接 成 商品 ID 串 ， 这 样 | 
就 可 以 实现 将 指定 的 商品 从 购物 车 中 移 除 操作 。 | 
说 明 : 

本 章 所 说 的 商品 ID 串 和 商品 数量 串 是 指 用 字符 “@” 进 行 连接 的 多 个 商品 的 ID 号 和 数 
量 值 ， 这 样 做 的 目的 是 使 用 一 个 变量 或 数据 库 的 一 个 字段 就 可 以 存储 多 个 商品 ID 或 数量 。 


(5) 更 改 购物 车 中 商品 的 数量 是 通过 changeNum0 方 法 实现 的 ， 该 方法 的 代码 如 下 : 
代码 位 置 ， 配套 资源 \mr\05\library\Cart.php | 
01 function changeNum($goodsId, $goodsNum){ | 

| 


02 $arrayIds = explode((@'. $this->idStD: /将 商品 ID 串 用 “@ ”分 割 成 数组 | 
03 $arrayNums = explode((@', $this->numStr); /将 商品 数量 串 用 “@ ”分 割 成 数组 ， 
04 for($i= 0: $i < count($arrayIds): $i++){ // 饥 历 商 品 ID 串 | 
05 if ($arrayIds[$i] 一 $goodsId){ // 如 果 查 找到 要 更 改 的 了 D | 
06 $arrayNums[$i] = $goodsNum: // 更 改 数量 | 
07 | 
08 } | 
09  @ Sthis->idstr= implode(@'. $arrayIds): // 重 新 合并 成 ID 串 | 
10 Sthis->numStr = implode((@' $arrayNums): /重新 合并 成 数量 串 | 
Tr | 
| 

< 人 关键 代码 解析 | 


@ 函数 implodeO 用 于 实现 将 指定 的 数组 的 所 有 元 素 使 用 特定 的 字符 进行 连接 形成 新 的 字符 串 。 

changeNum( 方 法 中 包含 两 个 参数 ， 分 别 为 要 更 改 商 品 的 ID 号 和 要 更 改 的 数量 。 在 该 
方法 内 部 ， 首 先 使 用 函数 explode0 将 商品 人 D 串 和 商品 数量 串 以 “@” 作 为 分 隔 符 进行 分 
割 操作 ， 并 将 分 割 后 的 字 串 分 别 保存 到 数组 中 ， 然 后 通过 for 循环 语句 遍历 商品 了 D 数组 ， 
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| 并 在 其 中 查找 要 更 改 数量 的 商品 ID, 查找 到 之 后 , 将 新 数量 值 赋 给 数量 串 中 对 应 的 数组 元 
| 素 , 最 后 使 用 函数 implode0 将 商品 劝 数 组 和 商品 数量 数组 中 所 有 元 素 分 别 重新 用 字符 “@” 
进行 连接 ， 组 成 新 的 商品 ID 串 和 商品 数量 串 。 
(6) 清空 购物 车 中 的 商品 ， 是 通过 Cart 类 的 setCartNull0 方 法 实现 的 。 实 现 清空 购物 
| 车 中 的 商品 ， 只 需 将 商品 ID 串 和 商品 数量 串 都 赋 为 空 串 即 可 。 具 体 实现 代码 如 下 : 


function setCartNullO{ 
S$this->idStr ="; // 清 空 商品 攻 串 
S$this->numStr ="; // 清 空 商品 数量 串 
} 


| (7) 通过 购物 车 类 中 的 方法 完成 对 商品 ID 串 和 商品 数量 串 操 作 后 ， 还 需要 定义 两 个 
| 方法， 分 别 用 来 获取 商品 ID 串 和 商品 数量 串 ， 实 现代 码 如 下 所 示 : 
代码 位 置 : 配套 资源 \mr\05\library\Cart.php 


01 function getIdStrO{ /获得 购物 车 的 商品 ID 串 
02 return $this->idStr; 

03 

04 function getNumStrO{ // 获 得 购物 车 的 商品 数量 串 
05 Teturn $this->numStr; 

06  } 


以 上 为 明日 网 上 书店 用 于 实现 购物 车 功能 的 Cart 类 的 属性 和 主要 方法 ， 通 过 Cart 类 
可 以 简化 程序 编码 复杂 程度 ， 使 购物 车 实现 的 思路 更 清晰 。 


5.3.5 ”分 页 类 


为 了 有 效 地 利用 页 面 资源 ， 设 计 出 合理 的 页 面 布局 ， 在 制作 明日 网 上 书店 的 图 书信 息 
展示 模块 时 ， 很 多 模块 均 采用 分 页 输出 的 显示 方式 。 如 果 每 个 图 书信 息 展 示 模块 都 编写 类 
似 的 代码 实现 分 页 ， 不 仅 会 降低 开发 效率 ， 而 且 也 给 程序 在 运行 环境 中 的 维护 带 来 很 大 负 
担 ， 为 了 解决 上 述 问题 ， 将 显示 分 页 功能 封装 成 分 页 类 ， 在 需要 使 用 分 页 展示 信息 的 页 面 
中 ， 只 需 调 用 该 类 的 相应 方法 即 可 实现 分 页 输出 功能 ， 下 面 对 分 页 类 的 实现 方法 作 系统 讲 
解 ， 首 先 创建 该 分 页 类 文件 pageDB.php， 并 将 该 文件 存放 在 library 文件 目录 下 ， 分 页 类 
的 相关 代码 如 下 : 

代码 位 置 ， 配套 资源 \mr\05\library\PageDB.php 

01 class PageDB{ 


02 function pageData ($sql, $connID. $pageSize. $page) { 
03 S$arrayPageInfo = array0: // 用 于 保存 分 页 信息 的 数组 
04 SnowPage = $page: // 当 前 页 码 


0 ©@ S$rs= $connID->PageExecute($sql. $pageSize. SnowPage): // 通 过 ADODB 的 
PageExecute() 方 法 获得 指定 页 码 的 记录 集 
06 


SarrayData = $rs->GetRows(): // 将 结果 保存 到 数组 中 
07 让 (count($arrayData) 一 01| $rs 一 false) { ”// 如 果 没 有 查询 到 内 容 , 则 返回 false 
08 Teturn false: 


dl 
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09 }else{ 
10 S$arrayPageInfo['data] = SarrayData: // 每 页 的 数据 
11 @ S$rsAll = $connID->Execute($sq)): 
了 $countRs = count($rsAll->GetRowsO): 
13 © S$countPage = ceil($countRs / $pageSize): 
14 SarrayPageInfo['pageSize’] = $pageSize: // 每 页 显示 记录 的 条 数 
15 S$arrayPageInfo['countRs'] = $countRs: /总 记录 数 
16 S$arrayPageInfo[page'] = $nowPage: // 当 前 页 
17 S$arrayPageInfo['countPage’] = $countPage: // 总 页 数 
18 S$arrayPageInfo['first] = 1: // 第 一 页 的 页 码 
19 if (Spage> 1) { 
20 S$arrayPageInfo['previous'] = Srs->AbsolutePage0 - 1; // 前 一 页 的 页 码 
21 }else{ 
2 S$arrayPageInfo['previous’] = 1: 
23 } 
24 if ($page < $countPage) { 
25 $arrayPageInfo['next'] = Srs->AbsolutePageO + 1;  ”// 后 一 页 的 页 码 
26 }else{ 
27 SarrayPageInfo['next'] = $countPage; 
28 } 
29 S$arrayPageInfo['last] = $countPage: // 最 后 一 页 的 页 码 
30 } 
31 Teturn $arrayPageInfo: 
32 } 
33 } 
Ah 关键 代码 解析 


@ PageExecute() 方 法 是 ADODB 抽象 层 实现 数据 分 页 显示 的 方法 。 
@ Execute( 方 法 为 ADODB 抽象 层 执 行 SQL 语句 的 方法 。 
四 函数 ceil0 用 于 对 浮 点 数 进行 向 上 取 整 。 


上 述 所 定义 的 分 页 类 实现 的 思想 是 : 设法 使 用 ADODB 数据 抽象 层 获取 指定 页 码 中 所 
显示 的 数据 ， 同 时 将 首页 、 上 一 页 、 下 一 页 、 尾 页 、 总 页 码 和 总 记录 数 都 作为 数组 元 素 ， 
然后 将 该 数组 作为 分 页 类 中 实现 分 页 方法 的 返回 值 返 回 ， 对 于 需要 分 页 的 模块 ， 只 需要 通 
过 分 页 类 获取 该 返回 数组 就 可 以 获得 所 有 分 页 所 需 信息 。 

在 实现 上 述 PageDB 分 页 类 时 ， 在 类 体内 只 定义 一 个 pageData0) 分 页 方法 ， 在 该 方法 
内 部 , 通过 ADODB 数据 抽象 层 根据 分 页 方法 的 SpageSize 和 $page 参数 获取 页 面 显示 的 数 
据 和 分 页 导航 参数 ， 并 保存 到 $arrayPageInfo 数组 中 返回 。 


5.3.6 工具 类 


在 开发 明日 网 上 书店 的 过 程 中 ,很 多 模块 都 需要 用 到 对 中 文字 符 串 的 截取 、HTML 标 

记 的 原样 输出 实现 以 及 调用 FckEditor 在 线 编辑 器 等 功能 。 为 了 提高 代码 的 重用 率 ， 将 上 
述 功 能 封装 成 工具 类 ， 下 面 介绍 该 工具 类 的 实现 方法 。 

(1) 在 library 文件 目录 下 创建 该 类 文件 UtilLphp 并 定义 该 类 的 属性 ， 充 分 考虑 到 项 


“ids 
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| 目 在 运行 环境 下 的 维护 工作 , 将 类 的 常用 配置 都 写 入 到 LzhConfig.ini 文件 中 实现 ， 所 以 该 
”类 的 属性 只 需要 一 个 用 来 保存 配置 文件 信息 的 数组 即 可 ， 代 码 如 下 : 
| var SarrayIni: /用 于 保存 LzhConfig ini 配置 文件 的 配置 信息 


(2) 定义 工具 类 的 构造 方法 。 在 构造 方法 中 通过 函数 parse_ini file0 解 析 LzhConfig.ini 
配置 文件 ， 实 现代 码 如 下 : 
function Util 0 
1 
$this->arrayImi= parse_ini_file('config/lzhConfig.ini"); /解析 配置 文件 , 并 将 结果 保存 到 数组 中 
} 
| (3) 一 般 情况 下 ， 项 目的 开发 环境 和 运行 环境 所 存放 文件 的 根 目录 位 置 是 不 同 的 ， 
| 如 果 在 开发 过 程 中 均 采 用 相对 路 径 ， 则 将 程序 移植 到 其 他 环境 后 ， 用 户 不 用 对 配置 文件 做 
| 大 量 调整 工作 ;如 果 在 开发 过 程 中 使 用 绝对 路 径 ， 那 么 将 程序 移植 到 其 他 环境 后 ， 必 须 修 
| 改 程序 中 的 所 有 绝对 路 径 才能 使 程序 正常 运行 。 为 了 解决 上 述 问题 ， 可 以 在 LzhConfig.ini 
| 文件 中 指定 项 目的 根 目录 ， 然 后 在 需要 使 用 项 目 路 径 的 模块 中 读 取 配 置 文件 并 指定 项 目的 
| 根 目录 即 可 。 在 本 工具 类 中 ， 获 取 项 目 根 目录 是 通过 baseUrl0 方 法 实现 的 ， 代 码 如 下 : 
function baseUrl 0 
{ 
SarrayIni = $this->arrayIni; 
return $arrayIni["baseUrl]: // 将 配置 文件 中 的 网 站 根 目 录 返 回 
} 
| (4) 作为 电子 商务 类 网 站 ， 项 目的 很 多 模块 都 需要 对 货币 金额 以 特定 格式 输出 ， 为 
| 了 简化 操作 ， 在 工具 类 中 定义 moneyFormat0 方 法 来 封装 货币 金额 的 格式 化 操作 ， 其 代码 
| 如下: 
| function moneyFormat ($money) 
{ 


} 
| moneyFormat( 方 法 首先 通过 函数 number format0 将 金额 以 保留 2 位 小 数 的 格式 输出 ， 
| 然后 将 处 理 后 数据 中 高 位 的 “,” 替 换 为 空 ， 最 后 将 处 理 结果 返回 。 
| (5) 为 了 保持 所 输入 数据 按 原 格式 输出 ， 需 要 将 一 些 特殊 字符 转换 成 HTML 标记 ， 
| 由 于 在 项 目的 很 多 模块 需要 使 用 到 该 功能 ， 所 以 将 该 功能 在 工具 类 中 封装 成 方法 ， 其 实现 
| 代码 如 下 : 
代码 位 置 ， 配套 资源 \mr\05\library\Util.php 
01 function unHtml (Stext) 

{ 


return str_replace(",',", number_format($money, 2)); /返回 中 文 货币 格式 


02 
03 $str = htmlspecialchars($texb: // 将 特殊 字符 替换 成 HTML 转 意 标记 

04 $str=str_replace(chr(13)."<br>",$str); /将 换行 替换 成 标记 <br/> 

05 S$str = nl2br($str): // 在 每 个 新 行 前 加 入 HTML 换行 标记 <br/> 
06 $str=str_replace(chr(32)."&nbsp:".$str): // 将 空格 蔡 换 成 标记 $nbsp: 

07 Tetum $str: // 返 回 处 理 后 字符 串 
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(6) 使 用 PHP 提供 的 函数 substr0 截 取 中 文字 符 时 ， 经 常会 导致 截取 乱码 ， 在 制作 项 
目的 过 程 中 , 很 多 模块 都 需要 对 过 长 的 字符 进行 截取 , 所 以 在 工具 类 中 定义 msubstr0 方 法 ， 
其 主要 功能 是 对 中 文字 符 进行 截取 ， 其 代码 如 下 所 示 : 
代码 位 置 : 配套 资源 \mr\05\library\Util.php 


01 function msubstr ($str, $start, $len) 


2 

03 S$strlen = $start + $len: // 获 取 截 取 字符 长 度 

04 for ($i= 0: $i< $strlen: $i++) { /遍历 所 有 字符 

05 还 (ord(substr($str $i, 1)) > 0xa0) { // 判 断 是 否 为 中 文字 符 

06 Stmpstr = substr($str, $i, 2); // 如 果 是 中 文 则 截取 2 个 字 节 
07 $i++; 

08 } else{ 

09 Stmpstr = substr($str, $i, 1); /不 是 中 文 则 截取 1 个 字 节 
10 ) 

11 ITetum $tmpstr: // 返 回 结果 

2 


(7) 使 用 HTML 语言 提供 的 文件 域 对 文本 进行 编辑 ， 实 现 文本 特效 较为 复杂 ， 而 且 
不 能 达到 “所 见 即 所 得 ”的 效果 ， 为 了 解决 上 述 问题 ， 在 进行 Web 项 目 开发 时 ， 一 般 使 用 
FckEditor 在 线 编辑 器 作为 表单 的 文本 编辑 域 。 在 制作 明日 网 上 书店 的 过 程 中 , 很 多 模块 中 
均 应 用 到 在 线 编辑 器 ， 所 以 在 开发 该 程序 时 ， 可 以 将 FckEditor 编辑 器 的 代码 封装 在 Util 
工具 类 中 ， 以 便于 程序 的 调用 。 具 体 实现 代码 如 下 : 
代码 位 置 ， 配套 资源 \mr\05\library\Util.php 
01 function editor ($name. $value. $width = "100%', Sheight = '200") 


OZ 

03 require_once 'library/fckeditor/fckeditor.php': // 导 入 FckEditor 类 库 
04 SarrayIni = $this->arrayIni; // 获 取 配 置 文 件 内 容 
05 $oFCKeditor = new FCKeditor($name): // 实 例 FCKeditor 

06 $oFCKeditor->BasePath = SarrayIni[baseUrl] . /library/fekeditor/: ” /设置 FCKeditor 路 径 
07 SoFCKeditor->Width = $width: // 编 辑 器 的 宽度 

08 $oFCKeditor->Height = $height: /编辑 器 的 高 度 

09 $oFCKeditor->ToolbarSet = ' Default : 1/ 设置 工具 栏 样式 
10 S$oFCKeditor->Value = $value: // 初 始 值 

11 SoFCKeditor->Create(): // 创 建 编辑 器 
> 


以 上 所 讲解 的 内 容 为 明日 网 上 书店 所 使 用 的 主要 公共 类 的 内 容 ， 通 过 上 面 的 学 习 , 读 | 


者 可 以 掌握 项 目 开 发 中 常用 类 的 制作 思想 和 方法 ， 如 果 能 够 进一步 研究 ， 则 在 学 习 过 程 中 
一 定 能 明显 提高 个 人 的 编程 技能 。 


提示 : 
FckEditor 的 下 载 网 址 是 http://ckeditor.com/download. 


“Id 


~ 可 人 Be 项目 业 例 分 析 
54 首页 设计 


y 前 台 首 页 承载 并 显示 网 站 前 台所 包含 的 模块 ， 使 浏览 者 能 够 了 解 网 站 内 容 和 特点 。 下 
全 J | 面 介绍 明日 网 上 书店 网 站 前 台 首 页 面 的 设计 和 功能 实现 。 


03 5.4.1 首页 概述 


| 任何 一 个 成 功 的 Web 应 用 程序 都 离 不 开导 航 功能 。 在 明日 网 上 书店 开发 的 过 程 中 , 首 
页 主要 应 用 到 首部 导航 、 尾 部 导航 和 左 侧 导 航 。 为 了 保证 页 面 的 整洁 并 增强 页 面 的 可 维护 
性 ， 前 台 首 页 使 用 include 语句 来 包含 主要 的 功能 页 面 。 这 样 做 不 但 使 系统 具有 统一 的 风 
| 格 ， 并 且 可 以 增强 网 站 的 可 维护 性 ， 例 如 网 站 管理 者 对 导航 条 修改 时 ， 不 需 对 每 页 都 进行 
改动 ， 只 需要 修改 相应 的 文件 ， 这 样 可 以 在 很 大 程度 上 提高 系统 开发 效率 ， 并 且 给 维护 工 
作 带 来 极 大 方便 。 明 日 网 上 书店 首页 的 设计 效果 如 图 5.10 一 图 5.12 所 示 。 

人 设 为 首页 全 4 欢迎 直列 关 日 网 上 书店 【登录 ] [ 钢 刘 注册] 回 明日 加 书 排 御 网 上 嫩 忽 书 若 [议和 司 典 } 
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| 图 5.11 明日 网 上 书店 首页 主体 部 分 界面 
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图 5.12 明日 网 上 书店 尾部 导航 


5.4.2 首页 技术 分 析 


为 了 便于 读者 选 购 图 书 ， 在 制作 明日 网 上 书店 首页 时 ， 将 图 书 类 别 以 二 级 导航 树 的 形 
式 展现 出 来 。 制 作 导航 树 的 方法 有 多 种 ， 其 中 最 常用 的 是 递归 方法 ， 由 于 本 站 图 书 类 别 树 


只 有 两 层 ， 所 以 采用 双 层 购 套 循环 即 可 实现 。 首 先 在 index.php 文件 中 通过 下 述 代码 获取 | 
图 书 大 类 和 图 书 子 类 内 容 ， 实 现代 码 如 下 : 
代码 位 置 ， 配套 资源 \mr\05\index.php 

// 获 取 图 书 大 类 


01 
S$connID): 


S$bigtypes = $adminDB->executeSQL("select id, typename from tb_bigtype order by addtime", 


02 $smarty->assign('bigtypes', $bigtypes); 
/获取 图 书 小 类 


03 $smalltypes= $adminDB->executeSQL("select id, typename. bigtypeid 
04 from tb_smalltype order by addtime", $connID); 


05 $smarty->assiegn('smalltypes', $smalltypes); 


获得 图 书 大 类 和 子 类 信息 后 ， 就 可 以 在 模板 中 通过 Smarty 的 section 标签 遍历 这 两 个 
类 别 数 组 ， 并 实现 翌 套 循环 ， 模 板 文件 index.phtml 的 具体 代码 如 下 : 


代码 位 置 ， 配套 资源 \mr\05\views\index.phtml 


01 {section name=bID loop=$bigtypes} 
02 ”<!-- 使 用 section 遍历 所 有 类 别 --> 
03 <div style="width:195px"> 


04 <div style="width:100%; height:25px; text-align:left: padding-left:6px; padding-top:Spx: 
color:#990000"> 

05 ic&nbsp:{futil->unHtml p=$bigtypes[bID].typename} 

06 </div> 

07 <div style="width:100%"> 

08 {section name=sID loop=$smalltypes} 

0 9 ©@ {if $bigtypes[bID].id 一 $smalltypes[sID].bigtypeid} 

10 <div style="width:49%: height:18px: float:left; text-align:left: padding-left:12px"> 

11 &nbsp:<a href=" {util->baseUrl}/listbook- {$smalltypes[sID].id}- {if $cctype==1}1 

到 {elseif $cctype—2}2{elseif $cctype—3}3 {elseif $cctype 一 4}4 

13 {/if}.html" class="a4">{util->unHtml p=$smalltypes[sID].typename}</a> 

14 </div> 

15 {/if} 

16 {/section} 

7 </div> 

18 </div> 


到 全 人 
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说 
19  {/section} 


| Ah 关键 代码 解析 
@ 这 里 通过 证 语句 判断 子 类 的 bigtypeid 是 否 与 大 类 的 id 相等 ， 如 果 二 者 相等 则 说 明 该 子 类 属于 这 
个 大 类 。 


oo 上 述 代码 通过 Smarty 模板 的 section 标签 遍历 类 别 数组 。section 标签 必须 成 对 出 现 ， 
| 
| 
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| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
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| 
| 
| 
| 
| 
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| 
| 
| 
| 
| 
| 
| 
| 
| 
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| 
| 
| 
| 
| 
| 
| 
| 
] 


并 且 必 须 设 置 name 和 loop 属性 ，name 可 以 以 包含 字母 、 数 字 和 下 划 线 的 任意 组 合 命名 ， 
| section 标签 可 以 嵌 套 ， 但 必须 保证 嵌 套 的 name 唯一 ， 变 量 loop (通常 是 数组 ) 决定 循环 
| 执行 的 次 数 。 


| 5.4.3 首页 实现 过 程 


| 为 了 提高 代码 的 可 维护 性 ， 在 开发 明日 网 上 书店 的 过 程 中 ， 首 先 分 别 实现 网 站 头 部 导 
| 航 和 尾部 导航 ， 然 后 通过 PHP 的 包含 语句 include 或 require 将 二 者 加 载 到 主页 中 。 明 日 网 
| 上 书店 的 首页 主要 包括 图 书 类 别 导 航 、 新 书 推荐 展示 、 特 价 图 书展 示 、 热 卖 图 书展 示 、 期 
| 书 介绍 和 网 上 畅销 书 讯 等 几 个 模块 。 下 面 详细 介绍 明日 网 上 书店 前 台 首 页 的 实现 过 程 。 
| (1) 制作 网 站 头 部 导航 。 网 站 头 部 导航 主要 用 于 显示 网 站 logo、 网 站 主要 链接 和 实 
| 现 图 书信 息 搜索 功能 等 。 在 index.php 文件 中 ， 通 过 如 下 代码 包含 网 站 头 部 导航 。 
Tequire_once ‘header.php'; // 包 含 网 站 头 部 导航 

(2) 制作 网 站 尾部 导航 。 网 站 尾部 导航 主要 用 于 显示 网 站 版 权 信息 、 帮 助 导航 及 网 
| 站 备案 信息 ， 在 index.php 文件 中 ， 通 过 如 下 代码 包含 网 站 尾部 导航 。 
| Tequire_once ‘footer.php'; // 包 含 网 站 尾部 导航 

(3) 在 制作 电子 商务 类 网 站 时 ， 新 产品 展示 是 其 中 一 个 必要 的 模块 ， 同 样 ， 在 制作 
| 明日 网 上 书店 时 ， 为 了 向 客户 展现 最 新 的 上 架 图 书 ， 提 高 新 书 销量 ， 在 网 站 首页 增加 了 新 
| 书展 示 模块 。 在 制作 新 书展 示 模 块 时 ， 首 先 在 index.php 中 提取 出 新 书信 息 ， 其 实现 代码 
| 如 下 : 


| SnewBookinfos = $adminDB->executeSQL("select id. bookname. oldprice. newprice, bookimg from 
‘tb_bookinfo where isnew=1 order by addtime desc limit 0, 6", SconnID): // 查 询 新 书信 息 
| S$smarty->assign(‘newBookinfos'. SnewBookinfos): /赋值 给 视图 变量 
| 然后 在 views 文件 目录 下 的 index.phtml 模板 文件 中 ， 通 过 section 标签 循环 的 方式 展 
| 示 新 书信 息 ， 代 码 如 下 : 
代码 位 置 ， 配套 资源 \mr\05\iews\index.phtml 

01 {section name=nbID loop=$newBookinfos} 

02 <div style="width:33%: height:220px: float:left: line-height:25px"> 

03 <li style="display:inline"><a hre=" {util->baseUrl}/bookinfo- {$newBookinfos [nbID]id} html> 

04 <img src="{$system[0].bookimgurl}/{$newBookinfos[nbID].bookimg}" width="100" 


05 height="125" style="border: 1px solid #123456" /></a></li> 
06 <br> 
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07 <li style="display:inline"><strong><a href=" {util->baseUrl}/bookinfo- {$new Bookinfos 
[nbID].id} html' 

08 class="al" title=" {util->unHtml p=$newBookinfos[nbID].bookname}"> 

09 {util->unHiml p=SnewBookinfos[nbID] booknameltruncate:20:". "false} </a> </strong></li> 

10 <br> 

11 <li style="display:inline"> 

12 市 场 价 : <img src=" {util->baseUrl}/img/mark green.gif" />&nbsp:<s> 

13 {util->moneyFormat p=$newBookinfos[nbID].oldprice}</s><br> ! 

14 <font color="#FF0000"> 明 日 价 : <img src=" {util->baseUrl}/img/mark red.gif' />&nbsp; | 

15 {util->moneyFormat p=$newBookinfos[nbID].newprice}</font> 

16 </> 

7 <br> 

18 <1i style="display:inline"><a href=" {util->baseUrl}/cart-{$newBookinfos [nbID].id} -add. html"> 


19 <img src="{util->baseUrl}/img/button order.gif" border="0"/></a>&nbsp; 

20 <ahref="{util->baseUrl}/bookinfo-{$newBookinfos[nbID].id}.html"> 

21 <img src=" {util->baseUrl}/img/button_info.gif" border="0"/></a></li> 

22 </div> 

23: {/section} 

在 明日 网 上 书店 首页 ， 除 新 书 内 容 展示 外 ， 还 有 特价 图 书展 示 、 热 卖 图 书展 示 、 期 书 

介绍 等 功能 ， 其 实现 过 程 与 新 书展 示 的 实现 过 程 类 似 ， 这 里 不 再 袭 述 ， 详 细 实现 代码 请 参 
见 本 书 附带 源码 配套 资源 。 


5.5 ”用户 模块 设计 


为 了 使 网 站 经 营 者 和 用 户 之 间 建 立 良好 的 沟通 桥梁 ， 每 一 个 优秀 的 网 站 程序 中 ， 用 户 
模块 是 不 可 缺少 的 ， 网 站 运营 商 可 以 通过 用 户 模块 收集 用 户 信息 ， 从 侧面 讲 ， 一 个 网 站 的 
用 户 量 可 能 直接 影响 到 网 站 的 人 气 和 经 济 效益 ， 下 面 将 详细 介绍 明日 网 上 书店 网 站 的 用 户 
模块 的 实现 过 程 。 


5.5.1 用 户 模块 概述 


明日 网 上 书店 的 用 户 模块 的 主要 功能 是 为 用 户 提供 服务 ， 建立 网 站 管理 者 和 用 户 沟通 
的 桥梁 。 明 日 网 上 书店 的 用 户 模块 主要 包括 用 户 注册 、 用 户 登 录 、 用 户 注册 信息 修改 、 用 
户 密 码 修改 、 查 看 提交 订单 信息 和 查看 在 网 站 上 的 消费 情况 等 功能 。 
5.5.2 ”用户 注册 


用 户 注册 模块 主要 用 于 收集 用 户 的 注册 信息 ， 用 户 参 与 该 站 点 活动 时 ， 通 过 登录 模块 
成 功 登 录 后 即 可 参与 进来 。 用 户 注册 模块 不 仅 可 以 方便 用 户 参 与 本 站 活动 ， 也 是 对 网 站 人 
气 的 积累 。 明 日 网 上 书店 的 用 户 注册 表单 如 图 5.13 所 示 。 


si 


| ES 
有 .以 全 了 系 


ER 
读 杜 姑 生 成 4 证 租 内 雁 嘲 写 
ER 
[| ee 
这 世人 以下 


图 5.13 用 户 注册 表单 


了 解 明 日 网 上 书店 用 户 注册 表单 的 结构 后 ， 下 面 介绍 用 户 注册 模块 的 具体 实现 过 程 。 
(1) 制作 用 户 注册 表单 UI 界面 。 根 据 需求 分 析 ， 用 户 注册 表单 除了 用 户 名 和 登录 密 
码 等 信息 外 ， 为 了 方便 与 用 户 进行 沟通 ， 还 需要 用 户 的 联系 电话 、E-mail 地 址 和 邮编 等 信 
| 息 ， 据 此 编写 明日 网 上 书店 的 注册 表单 的 主要 代码 如 下 : 
| 代码 位 置 ， 配套 资源 \mr\05\views\getuserinfo.phtml 


| 
| 
| 
| 
| 
| 
| Eg E ee 
| 
| 
| 
| 
| 
| 
| 
| 


01 <form name="form reg" method="post" action=" {util->baseUrl}/getuserinfo.php" 
02 onSubmit="return chkreginfo(form reg.'all)"> 
03 <table width="90%" border="0" align="center" cellpadding="0" cellspacing="0"> 


04 <tr> 

05 <td width="22%" height="30"><div align="right"> 用 户 昵 称 : </div></td> 
07 onBlur="chkreginfo(form reg.0, ", '{util->baseUrl}")"></td> 

08 <td width="25%"><div id="chkusernce" style="color:#FF0000"></div></td> 
09 </t> 

10 <t> 


11 ”<td height="30"><div align="right"> 登 录 密 码 : </div></td> 
12 <td height="30" colspan="3">&nbsp: 
13 <input type="password" name="userpwdl" size="25" class="input” onBlur="chkreginfo 


| 
| 
| 
| 
| 06 <td colspan="3">&nbsp:<input type="text" name="usemc" size="20" class="input" 
| 
| 
| 
| 
| 
| (form reg.1)" ></td> 


14 <td height="30"><div id="chkuserpwd1" style="color:#FF0000"></div></td> 


| 
| 15 </> 
| 16 <!-- 此 处 省 略 部 分 表单 元 素 实现 代码 ， 请 详 见 本 书 配套 资源 --> 
| 17 <t> 
| 18 <td height="30"><div align="right"> 验 证 码 : </div></td> 
| 19 <td width="1796" height="0">&nbsp: 
| 20 <inputtype="text" name="xym" size="8" class="input" onBlur="chkreginfo(form reg.12)"/> 
| 21 <input type="hidden" value="" name="xyml"></td> 
| 22 <td width="12%"> 
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23 <script language="javascript"> 

24 var numl=Math round(Math randomO*10000000): 

25 varnum=numl.toString0.substr(0.4): 

26 document .write("<img name=codeimg4 

27 src="{util->baseUrl}/xym.php?num="+num.substr(0,1)+"&baseUrl={util->baseUrl}>"): 
28 document write("<img name=codeimg5 

29 src=" {util->baseUrl}/xym.php?num="+num.substr(1.1)+"&baseUrl={util->baseUrl}'>"): 
30 document.write("<img name=codeimg6 Note 
3 src=" {util->baseUrl}/xym.php?num="+num.substr(2,1)+"&baseUrl={util->baseUrl}>"); 
32 document.write("<img name=codeimg7 

33 src=" {util->baseUrl}/xym.php?num="+num.substr(3.1)+"&baseUrl={util->baseUrl}'>"): 
34 form reg.xym!l.value=num; 

<!-- 该 方法 用 于 实现 重新 为 验证 码 赋 值 --> 

35 function code 101ldelim} 


36 var num1=Math.round(Math.random()*10000000): 

37 var num=numl.toString0.substr(0.4): 

38 document.codeimg4.src=" {util->baseUrl}/xym.php?num="+num.substr(0.1)+"&baseUrl= 
{util->baseUrl}"; 

39 document.codeimg5.src=" {util->baseUrl}/xym.php?num="+num.substr(1.,1)+"&baseUrl= 
{util->baseUrl}"; 

40 document.codeimg6.src=" {util->baseUrl}/xym.php?num="+num.substr(2.1)+"&baseUrl= 


{util->baseUrl}"; 
41 document.codeimg7.src=" {util->baseUrl}/xym.php?num="+num.substr(3,1)+"&baseUrl= 
{util->baseUrl}"; 


42 form reg.xyml.value=num; | 
43 {rdelim} | 
44 </script></td> | 
45 <td width="24%"><a hre 人 "javascriptcode_10" class="al"> 看 不 清 </a></td> | 
46 <td height="0"><div id="chkxym" style="color:#FF0000"></div></td> | 
47 </t> | 
48 <tr> | 
49 <td height="40" colspan="5"><div align="center"> | 
50 <input type="submit" value=" 立 即 注册 " class="btn_grey"> | 
Si <input type="reset" value=" 重 置 " class="btn_grey"> | 
52 </div> | 
33 </td> | 
54 <> | 
55 ‘</table> 

56 </form> 


在 制作 用 户 注册 表单 时 ， 表 单元 素 通 过 HTML 语言 的 <input> 标 签 实现 ， 其 实现 方法 
相对 简单 ， 这 里 最 为 关键 的 是 图 片 验证 码 的 实现 过 程 。 

在 制作 图 片 验证 码 时 , 首先 通过 JavaScript 中 Math 对 象 的 random0 方 法 产生 一 个 随机 
数 ， 并 通过 Math 对 象 的 round( 方 法 截取 该 随机 数 的 前 4 位 ， 然 后 再 分 别提 取 该 随机 数 的 
每 一 位 ， 并 将 提取 的 每 一 位 数字 通过 GET 方法 传递 到 xym.php 页 面 ， 在 xym.php 页 面 中 
根据 传递 过 来 的 数组 ， 读 取 相 应 的 图 片 ， 并 将 结果 显示 出 来 ，xym.php 文件 中 的 实现 代码 
如 下 : 


ss 
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$num=$_GET[num]: /获得 传递 的 数字 
$address="img/code/". Snum_ "gif' /获取 对 应 图 片 地 址 
$fp=fopen($address."r"): // 打 开 对 应 的 图 片 

echo fread($fp,filesize($address)): // 将 图 片 以 二 进 制 的 形式 输出 到 浏览 器 
fclose($fp): /关闭 打开 的 图 片 


将 生成 的 随机 数 传递 到 xym.php 文件 的 同时 ， 将 该 随机 数 赋 给 一 个 隐藏 域 ， 这 样 在 验 
证 用 户 输入 的 验证 码 是 否 正确 时 ， 就 可 以 根据 用 户 输入 的 内 容 和 该 隐藏 域 的 value 值 进行 
对 比 得 出 结果 ， 如 果 二 者 相等 则 说 明 用 户 输入 的 验证 码 正确 。 

(2) 当 用 户 在 输入 注册 信息 时 ， 会 对 用 户 输入 的 内 容 进行 实时 验证 ， 本 站 对 用 户 输 
入 信息 的 验证 是 通过 JavaScript 实现 的 ， 其 中 对 用 户 身份 唯一 性 验证 是 在 js 文件 目录 下 的 
fanjs 文件 中 实现 的 。 相 关 代码 如 下 : 

代码 位 置 ， 配套 资源 mm0sjsdunjs 


01 function chkreginfo(form. mark, edit, baseUrD) { 


02 让 ((mark 一 01 mark 一 "all) && edit!= "edit") { 

03 下 (formuserncvalue =—"") { // 浏 断 用 户 输入 的 昵称 是 否 为 空 

04 chkusemc innerHTML = "请 输入 用 户 昵 称 ! ": /如 果 为 空 则 给 出 提示 

05 form.usernc.style.backgroundColor = "#FF0000": /更 改 用 户 昵 称 文本 杠 
的 背景 为 红色 

06 Teturn false; 

07 } else { 

08 var xmlobj: // 定 义 XMLHttp 对 象 

09 if (window.ActiveXObject) { // 如 果 是 windows 系统 

10 xmlobj = new ActiveXObject("MicrosoftXMLHTTP"):// 通 过 ActiveXObjectO 
实例 XMLHttp 对 象 

11 } else if (window.XMLHttpRequest) { 

12 xmlobj=newXMLHttpRequest0: /通过 XMLHttpRequest0 实 例 XMLHttp 对 象 

13 | 

14 xmlobj.onreadystatechange = fun: // 设 置 回调 函数 

15 xmlobj.open("GET", // 通 过 GET 方法 向 服务 器 发 送 数据 

16 baseUrl + "/chkunc.php?unc=" + form.usernc.value. true): 

17 xmlobj.send(null): 

18 function fun0 { /定义 回调 函数 

19 if (xmlobj.readyState 一 4 && xmlobj.status 一 200) { 

20 让 (xmlobjresponseText 一 "0") { /如 果 返 回 0 则 说 明 昵称 被 占用 

21 chkusernc.innerHTML = "该 昵称 已 被 占用 !"; 

23 form.usernc.style.backgroundColor = "#FF0000": 

24 Tetum false: 

25 } else { 

26 chkusernc.innerHTML = "": 

2 form.usernc.style.backegroundColor = "#FFFFFF"; 

28 

29 } 

30 » 

SY 有 

32 } 

33 ”.… /省略 代 码 请 详 见 本 书 配套 资源 


“2 


34 Tetum tme: 


如 果 使 用 Ajax 框架 jQuery 技术 实现 上 述 功 能 ， 只 需 $.get0 方 法 即 可 ， 其 实现 方法 为 : 
$.get(baseUrl + "/chkunc.php?unc=" + form.usemc.value. null. function(data){ 
/回调 函数 
了 


上 述 代码 首先 根据 不 同 浏览 器 的 类 型 生成 HTTP 请 求 对 象 ， 然 后 使 用 该 对 象 的 open0 
方法 将 用 户 输入 的 昵称 传递 给 chkunc.php 页 面 , 并 根据 从 chkunc.php 页 面 的 返回 值 判断 用 
户 输入 的 昵称 是 否 已 经 被 占用 ， 其 中 chkunc.php 的 关键 代码 如 下 : 

代码 位 置 : 配套 资源 \mr\05\chkunc.php 

01 require once 'lzhinc.php'; // 包 含 公共 类 
02 $arrayunc=$adminDB->executeSQL 


03 ("selectid,usernc from tb_user where usernc=".$ GET["unc"]."",$connID); /查找 用 户 昵称 
04 if($arrayunc) 


04 echo 0; // 如 果 查 找到 则 返回 0 
05 else 
06 echo 1: // 没 有 查找 到 则 返回 1 


(3) 用 户 输入 的 内 容 成 功 通 过 数据 有 效 性 验证 后 ， 所 有 输入 的 内 容 将 被 提交 到 
getuserinfo.php 页 面 中 进行 保存 ， 该 页 面 用 于 保存 用 户 注册 信息 的 关键 代码 如 下 : 
代码 位 置 ， 配套 资源 \mr\05\getuserinfo.php 


01 require once (header.php’); // 包 含 header.php 文件 
02 if(isset($ POST["userne"]) && $ POST["userne"] !="") { 1/ 判断 是 否 提交 了 表单 
03 if (! $adminDB->executeSQL("select id usernc from 

04 tb userwhereusernc=".$ POST["usermne"]."", $connID)) { /判断 昵称 是 否 被 占用 
05 Stime = date("Y-m-d H:i:s"); /获取 注册 时 间 

06 if ($adminDB->executeSQL("insert into tb user 

07 (usernc,truename,pwd,email,sex,tel,qq,address,logintimes.regtime,lastlogintime,ip,yb,usertype, 
08 answer,question,truepwd.photo,score) 

09 Values(" .$ POST["useme"]."".$ POST["uename"]."" .mdS(tim($ POST ["userpwd1"D).". 
10 ™. $ POST["email"].",".$ POST["sex"]."".$ POST["tel"]."".$ POST["qq"].". 


11  ".$ POST["address"]. "0,'$time''Stime,".$ SERVER[REMOTE ADDR].™".$ POST["yb"].", 
12 0".$ POST["answer"].",".$ POST["question"] . "." .trim($ POST["userpwd1"]) .", 
13  ". "img/face/".$ POST["photo"]. "30)", $connID)) { // 保 存 用 户 注册 信息 


14 if (isset($_SESSION["unc"]) && $_ SESSION["unc"] (="") { 

15 unset($_SESSION["unc"]): 

16 3 /销毁 原来 登录 用 户 的 登录 昵称 

17 Session register("unc"): // 注 册 新 的 用 户 昵称 到 session 范围 

18 $ SESSION["unc"] = trim($ POST["userne"]): 

19 ©@ 让 (isset($_SESSION[toUrl]){ // 获 取 要 跳 转 的 页 面 ， 并 进行 跳 转 

20 echo "<script>window.ocation href=" . $util->baseUrlO . "/" . $_SESSION[toUal] . 
</script>"; 


“1 
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| 21 }else{ 
| 2 echo "<script>window.location .href—" . $util->baseUrlO . "/regsuccess.html'; 
by 
}else{ 


echo "<script>alert( 注 册 失 败 ， 请 重 试 ! )</script>"; 


b 
ne | 27 eet 
28 echo "<script>alert( 该 昵称 已 经 被 他 人 注册 ! ')</script>"; 
| 29 } 

30 | 
31 $smarty->display(getuserinfo .phtml): 
32 require once 'footerphp': 


Ah 关键 代码 解析 
@ 这 里 将 注册 成 功 后 要 返回 的 页 面 保存 到 session 中 。 


当 用 户 的 浏览 器 禁用 JavaScript 脚本 功能 时 ， 用 户 注册 表单 中 用 户 输入 昵称 的 唯一 性 
验证 可 能 无 法 实现 ， 所 以 在 保存 用 户 提交 的 注册 信息 前 ， 首 先 使 用 数据 库 管 理 类 的 
executeSQL() 方 法 查询 是 否 存在 和 用 户 提交 昵称 相同 的 注册 用 户 名 称 ， 如 果 存 在 ， 则 提示 
该 昵称 已 被 占用 ， 并 返回 到 注册 页 面 提示 用 户 重新 填写 注册 信息 ; 反之 ， 则 将 提交 用 户 的 
注册 信息 ， 并 将 数据 保存 到 数据 库 中 。 


5.5.3 ”用户 登录 


用 户 在 明日 网 上 书店 购买 图 书 时 首先 需要 登录 站 点 ， 这 样 就 可 以 记录 购买 人 信息 ， 并 
且 在 用 户 中 心 的 订单 查询 模块 也 可 以 根据 当前 登录 用 户 查 询 到 该 用 户 的 所 有 订单 信息 ， 明 
日 网 上 书店 的 用 户 登录 表单 如 图 5.14 所 示 。 


长 内 而 | 孩 书 熙 


明日 科 : 
WHW mrpccoks-cn 


您 委 前 的 位 加: 量 日 同上 书店 ))》 用 户 多 好 


用 记 zooEt83 © es 


SD: HO aED] MR 

5 博 丰 月 户 E 广 下 输 和 从 丰 
过 有 册 ， 计 和 注册 力 涪 员 
ME 
于] ED tne 可 有 = 从 国 上 二 二 


MERE 


图 5.14 用 户 登 录 表单 
了 解 明 日 网 上 书店 的 用 户 登 录 表单 的 基本 结构 后 ， 下 面 对 用 户 登录 模块 的 实现 过 程 进 
行 讲解 。 
(1) 建 立 登录 表单 的 UI 界面 ,用 户 登录 表单 的 表单 元 素 是 通过 HTML 语言 的 <input> 
标签 实现 的 ， 其 实现 过 程 中 所 使 用 的 关键 技术 与 注册 表单 类 似 ， 这 里 不 再 袭 述 。 
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人 

〈2) 当 用 户 单 击 “ 登 录 ” 按 钮 后 ， 登 录 处 理 页 将 对 用 户 输入 的 用 户 名 、 密 码 和 验证 
码 进行 有 效 性 验证 ， 如 果 验 证 通过 ， 则 将 用 户 输入 的 数据 提交 到 login.php 中 进行 处 理 。 
getuserinfo php 的 关键 代码 如 下 所 示 : 


代码 位 置 : 配套 资源 \mr\05\getuserinfo.php 
01 <?php 

02 require once ‘header.php': 

03 SerrorMsg="; 


04 if (isset($ POST[usermc]) && $ POST['usemc] =") { 1/ 判断 是 否 提 交 了 表单 

05 $usemc =trim($_ POST[msernc']): /获得 提交 的 用 户 名 

06 $pwd=trim($ POST[userpwd]): // 获 得 提交 的 登录 密码 

07 $user = $adminDB->executeSQL("select id usernc from tb user 

08 ”where usermc=". $usemc . " and pwd=" . md5($pwd) . "". $connID); ”// 按 用 户 名 和 密码 查询 用 户 

09 if(! $user) { 

10 SerrorMsg =' 用 户 名 或 密码 输入 有 误 ! '; 

11 }else { 

12 这 (isset($_SESSION["unc"])) { /销毁 原 登 录用 户 信息 ， 并 注册 新 登录 用 户 信 
息 给 session 变量 

13 session Unregister(unc'"): 

14 } 

15 $_SESSION['"unc'] = Susemec: 

16 @$adminDB->executeSQL("update tb_user 


地 set logintimes=logintimes+l ,lastlogintime =" . date(Y-m-d H:i:s) . "ip="”. $ SERVER 
[REMOTE ADDR]." 
18 ”where usemc='" .$ SESSION['unc] . "". SconnID): /更 改 用 户 的 登录 信息 


it9 if(isset($_ SESSION['YoUrI])) { 

20 echo "<script>window.location.href="" . $util->baseUrlO . "/" . $_ SESSION 
[toUrl].";</script>"; 

2 exitO; 

22 } else{ 

23 echo "<script>window.location. href=" . Sufil->baseUrlO . usercenterhtml': </script>"; 

24 exitO; 

25 轩 

26 } 

到 


28 $smarty->assign('errorMsg', $errorMsg); 
29 $smarty->display(login.phtml): 
30 require_once 'footerphp': 


上 述 代码 中 ,首先 需要 定义 变量 $errorMsg, 该 变量 用 来 保存 登录 表单 在 提交 数据 处 理 | 


过 程 中 的 错误 信息 (如 登录 失败 信息 等 ), 然后 使 用 $_POST 全 局 数组 接收 用 户 提交 的 用 户 
名 和 登录 密码 值 ， 并 使 用 数据 库 管理 类 的 executeSQL0O 方 法 执行 查询 语句 来 判断 用 户 输入 
的 用 户 名 和 密码 是 否 正确 ， 如 果 正 确 ， 则 更 改 用 户 登 录 次 数 和 最 后 登录 时 间 ; 反之 ， 则 将 
登录 失败 信息 赋 给 变量 $errorMsg， 并 传递 给 login.phtml 模板。 

5.5.4 用 户 中 心 


明日 网 上 书店 用 户 中 心 模块 主要 用 于 实现 用 户 对 其 注册 信息 执行 修改 、 用 户 登 录 密 码 
修改 、 用 户 订单 查询 和 意见 的 反馈 等 操作 ， 其 界面 如 图 5.15 所 示 。 
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3 
tl: 攻 司 


证: 7 


Eel: im 


| 画 到 


| 图 5.15 用 户 中 心 页 面 

1.， 修改 个 人 信息 

用 户 成 功 注册 成 为 明日 网 上 书店 的 会 员 后 ， 可 以 通过 单 击 用 户 中 心 页 面 的 “修改 个 人 信 
息 ” 超 链接 对 注册 信息 进行 修改 。 用 户 中 心 修改 个 人 信息 的 表单 如 图 5.15 所 示 ， 默 认 情 况 
下 该 页 面 会 将 当前 登录 用 户 的 注册 信息 填充 在 信息 表单 中 。 当 用 户 修改 个 人 信息 并 单 击 “ 更 
| 改 ”按钮 后 ， 用 户 的 个 人 信息 将 被 提交 到 usercenterphp 页 面 进行 处 理 ， 其 关键 代码 如 下 : 

代码 位 置 ， 配 套 资源 \mr\05\usercenter.php 


01 Tequire_once "headerphp': 
02 if(!isset($ SESSION[unc]) ||$ SESSION[unc] 一 "){ /判断 用 户 是 否 已 经 登录 


03 echo "<script>alert( 禁止 非 登录 ! ;window.location.href=" . Sutil->baseUrlO . 
| w/index.html':</script>"; 

04 exit(); 

05 

07 if (! $adminDB->executeSQL("update tb_user 

08 set tmename=" . $ POST[tmename] . ", sex=" . $_ POSTT'sex] . ". tel=". $_POST['tel] .", 


09 email=".$ POST[email].", qq=".$ POST[qq]. ". yb=".$_POST['yb] .", address=" . 


| 
| 
| 
| 
| 
) 
| 06 ”这 (isset($_POST['truename']) &&$_POST['truename'] !=") { // 判 断 是 否 已 经 提交 了 表单 
| 
| 
| $ POST[address]." 

| 


10 Where usernc=" . $_SESSION["unc'] . "". $connID)) { /修改 注册 信息 
I echo "<script>alert( 用 户 信息 更 改 失败 ! '):</script>"; 

12 } 

1 0 


| 
| 14 $user = $adminDB->executeSQL("select truename, sex, tel email, qq, yb. address 

| 15 ftom tb_user where usemc=" .$_SE14 SSION["unc'] . "". SconnID): // 重 新 查询 用 户 信息 
16 $smarty->assign(user. $user): 

5 $smarty->display('usercenter.phtml'); 

| 18 require once footerphp': 


| 注意 : 
| 在 类 似 用 户 中 心 或 后 台 管理 模块 中 ， 处 理 文件 首先 应 该 判断 用 户 是 否 已 经 登录 ， 如 果 
当前 用 户 没有 登录 网 站 ， 则 页 面 会 自动 跳 转 到 首页 或 用 户 登 录 页 面 ， 这 样 可 以 防止 非法 用 
| 户 直接 通过 地 址 栏 访问 。 


| 
到 。186 。 
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上 述 代码 首先 判断 session 变量 中 是 否 存在 une 的 值 , 如 果 不 存在 , 则 说 明 当前 访问 者 | 


并 没有 登录 ， 这 时 页 面 将 提示 错误 登录 信息 给 当前 用 户 ， 并 将 页 面 定 向 到 首页 ， 反之， 使 | 

用 数据 库 管理 类 的 executeSQL( 方 法 更 改 用 户 信息 ， 并 将 更 改 后 的 信息 重新 回填 到 用 户 信 | 

息 更 改 表单 。 | 全 内 
2. 修改 登录 密码 


通过 用 户 中 心 的 修改 登录 密码 模块 可 以 对 用 户 的 登录 密码 进行 修改 ,用 户 密码 修改 表 | 
单 包括 原 密码 输入 文本 框 、 新 密码 输入 文本 框 和 确认 新 密码 输入 文本 框 3 个 表单 元 素 , 如 | 
图 5.16 所 示 。 | 


长 加 而 明日 乔 技 好 后 
WW-mrbooks.cn 


计 | 狼 话 陈 | 加 到 辣 全 | 生 作 大 组 “时 咏 委 计 | 同 结 与 一 信 ， 办公 以 件 | 去 全 


图 5.16 用 户 密码 修改 表单 | 

| 

用 户 在 密码 修改 表单 按 要 求 填写 完 密码 信息 并 单 击 “ 更 改 ” 按 钮 提交 表单 后 ， 所 有 内 | 

容 将 被 提交 到 usercenterchangepwd.php 页 面 来 对 密码 进行 更 改 ， 其 代码 如 下 : | 
代码 位 置 ， 配 套 资源 \mr\05\usercenterchangepwd.php 


01 <?php 
02 require once 'header.php': 
03 ”这 (!isset($_SESSION["unc') |$_SESSION[unc] 一 ") { ”// 判 断 用 户 是 否 已 经 登录 


04 echo "<script>alert( 禁止 非 登录 ! "):window.location.href=" . S$util->baseUrl0 . 
Windex.html':</script>"; | 
05 exitO: | 
06 } | 
07 ”让 (isset($_ POST[oldpwd]) && $ POST[oldpwd] =") { // 判 断 用 户 是 否 已 经 提交 了 表单 | 
08 if (! $adminDB->executeSQL("select id usernc from tb_user | 


09 whereusermc=".$ SESSION[unc] ." andpwd=" .md5($ POST[oldpwd]) . "", SconnID)) { 
10 echo "<script>alert(' 原 密码 输入 有 误 ! "):</script>"; // 验 证 原 密码 是 否 正确 


| 
11 jelse{ | 
1 if ($adminDB->executeSQL("update tb user | 
13 setpwd=".md5($ POST[pwdl]) . "tmuepwd=" .$ POST[pwd1]." | 
14 whereusemc=".$ SESSION[unc] . "". $connID)) { /执行 更 改 密码 操作 ! 
15 echo "<script>alert( 密 码 更 改 成 功 ! ):</script>": | 
16 } else { | 
jb echo "<script>alert( 密 码 更 改 失 败 ! ):</script>": | 
18 } | 
19 } | 
200 | 
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21 $smarty->display(usercenterchangepwd.phtml): 
| 22 require once 'footerphp' 

| 上 述 代 码 首 先 判断 用 户 是 否 非法 登录 ， 然 后 判断 用 户 输 入 的 原 密码 是 否 正 确 ， 如 果 正 
多 和 | 确 ， 则 将 用 户 密码 更 改 成 新 值 ， 反 之 ， 给 出 错误 提示 。 


Xe | 3， 意见 反馈 
| 用户 在 参与 本 站 活动 时 ， 如 果 对 网 站 的 管理 或 运营 存在 建议 或 意见 ， 可 以 通过 单 击 用 
| 户 中 心 页 面 的 “意见 反馈 ” 超 链接 将 反馈 的 个 人 意见 提交 到 网 站 管理 后 台中 。 明 日 网 上 书 
| 店 的 意见 反馈 表单 如 图 5.17 所 示 。 
| 
| 


久生 类 :由 出 向 坎 人 和 内 裕 间 二 


质问 责 公 司 的 p 二 二 查 辣 册 什么 时 从 区 入 版 


0 DO) 


ER 人 


图 5.17 用 户 意见 反馈 表单 
当 用 户 填写 完 个 人 建议 并 提交 表单 后 将 通过 如 下 代码 保存 用 户 的 反馈 信息 。 其 中 意见 
反馈 的 主要 实现 代码 在 userfeedback.php 文件 中 。 
代码 位 置 ， 配 套 资源 \mr\05\userfeedback.php 
01 这 (!isset($_SESSION['"unc") | $_SESSION["nc] 一 ) {// 判 断 用 户 是 否 已 经 登录 


02 echo "<script>alert( 禁止 非 登 录 ! ');window.location.href=" . S$util->baseUrl( . 
"/index.html';</script>"; 

03 exitO; 

a 


| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 05 if(isset($ POST['title]) && $ POST['itle] !(=") { 1/ 判断 用 户 是 否 已 经 提交 了 表单 
| 06 if ($adminDB->executeSQL("insert into tb_feedback(title, content, addtime, usernc) 
| 07 values(" . $_ POST['itle] . " "”. $ POST[content] . ", "”. date(Ym-d His) .", ™. 
| $_SESSION[unc] . 
| 08 ”SconnID)){ ”// 保 存 用 户 的 意见 反馈 信息 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
上 E 
| 
| 
| 
| 
j 


09 。 echo "<script>alert( 您 的 反馈 信息 已 经 成 功 保存 ， 谢 谢 您 的 支持 ! :</script>"; 
和 ed ee 请 重 试 ! 0);</script>"; 
3 
5.5.5 ” 找 回 登录 密码 
如 果 用 户 忘记 了 登录 密码 或 者 密码 被 非法 更 改 ， 可 以 通过 明日 网 上 书店 网 站 的 找 回 密 
码 模块 实现 密码 找 回 ， 找 回 密码 的 实现 过 程 如 图 5.18 一 图 5.21 所 示 。 
“Bs 
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BE 
明日 科技 | 


明日 科技 | 


图 5.18 找 回 密码 第 1 步 图 5.19 找 回 密码 第 2 步 
于 执 回 者 后 - Micraes 必 =| 口 |x| ETErTE =| 口 x| | 


图 5.20” 找 回 密码 第 3 步 图 5.21 重 设 密码 | 
了 解 明日 网 上 书店 用 户 登 录 密 码 找 回 的 操作 步骤 后 ， 下 面 对 密码 找 回 的 具体 实现 过 程 | 
进行 讲解 。 
(1) 找 回 密码 首先 要 求 用 户 输入 登录 昵称 。 用 户 按 要 求 输入 登录 昵称 后 ， 单 击 “ 确 
定 ” 按 钮 ， 通 过 后 台 处 理 文件 判断 该 昵称 是 否 存在 ， 如 果 存 在 ， 则 允许 用 户 执行 下 一 步 操 
作 ; 反之 ， 给 出 用 户 不 存在 的 提示 信息 ， 其 实现 文件 findpwd.php 的 代码 如 下 : 
代码 位 置 ， 配 套 资源 \mr\05\findpwd.php 


01 S$nc=$ POST[nc]: // 接 收 用 户 提交 的 昵称 | 
02 $sql = mysql_query("select * from tb_user Where usernc=" . $nc ."", $conn); | 
03 。 $info = mysql 人 tch_array($sqD; /查询 用 户 是 否 存在 并 给 出 提示 | 
04 if ($info 一 false) { | 
05 echo "<script>alert( 无 此 用 户 !9:history backO:</script>": | 
06 exitO: | 
07 Jyelse{ | 
08 echo $info[question]: | 
09 } 


(2) 如 果 判 断 用 户 找 回 的 昵称 存在 ， 则 该 页 面 会 提示 用 户 根据 给 出 的 提示 问题 输入 
找 回 的 密码 答案 ， 用 户 输入 答案 后 ， 单 击 “ 确 定 ”按钮 ， 后 台 代码 将 判断 用 户 输入 的 答案 
是 否 正 确 ， 如 果 正 确 ， 则 允许 用 户 进 入 第 3 步 操作 。 验 证 密码 答案 问题 的 处 理 过 程 是 在 
showpwd.php 文件 中 实现 的 ， 其 实现 代码 如 下 : 
代码 位 置 ， 配 套 资源 \mr\05\showpwd.php 

01 <php 

02 include ("conn.php"); 

03 $nc=$ POSTInc]: 

04 $da=$ POST[dal: 
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05 $sql= mysql query("select * from tb User where usernc=" . $nc . "", $conn): 


06 $info=mysql fetch array($sqD: /查询 用 户 信息 

07 if($infofanswer] := $da) { // 济 断 用 户 输入 的 提示 答案 是 否 正确 
08 echo "<script>alert(' 提 示 答 案 输入 错误 !):historybackO:</script>": 

09 exit(); 

10  }else{ 

11 “…/ 省 略 代码 用 于 显示 用 户 操作 选项 

2 

> 


(3) 如 果 用 户 输入 的 密码 提示 答案 正确 ， 则 会 显示 用 户 下 一 步 操作 选择 页 面 ， 该 页 
面 主要 有 两 个 超 链接 选项 : 第 一 项 用 于 显示 该 用 户 账户 的 原 密码 ; 第 二 项 用 于 设置 新 密码 。 
如 果 用 户 选 择 第 二 项 则 会 进入 如 图 5.21 所 示 的 用 户 密码 更 改 页 面 ,用户 可 以 在 该 页 面 输入 
新 密码 ， 然 后 单 击 “ 更 改 ” 按 钮 将 表单 内 容 提交 到 savechangepwd.php 页 面 实现 密码 更 改 
操作 ， 其 代码 如 下 : 
代码 位 置 ， 配 套 资源 \mr\05\savechangepwd.php 


01 <?php 

02 include once ("conn.php"); // 保 存 conn.php 数据 库 连 接 文 件 
03 S$tmepwd=$ POST[userpwdl]. // 获 得 真实 密码 

04 S$pwd=md5($tmepwd); // 获 得 md5 加 密 后 的 密码 


05 if (mysql_query("update tb_user set pwd='$pwd'.truepwd='$truepwd' 
06 ”where id=".$_POST["userid"] ."", $conn)) { /执行 密码 更 改 


07 echo "<script>alert( 密 码 更 改 成 功 !):history backO:</script>": 
08 } else{ 

09 echo "<script>alert( 密 码 更 改 失败 !):history.backO:</script>": 
1000 > 

11 mysql_close($conn); 

TEA 


5.6 图 书展 示 模 块 设计 


明日 网 上 书店 的 图 书展 示 模 块 ， 主 要 按 类 别 对 图 书 进行 展示 ， 其 中 包括 新 书展 示 、 特 
价 图 书展 示 、 热 卖 图 书展 示 和 期 书展 示 ， 从 而 便于 当前 浏览 用 户 通过 网 站 查看 图 书信 息 和 
购买 图 书 。 本 节 将 对 明日 网 上 书店 的 图 书展 示 模块 进行 介绍 。 


5.6.1 图 书 分 类 展示 


明日 网 上 书店 是 一 个 专业 的 IT 类 图 书展 示 和 销售 平台 ， 为 了 方便 读者 选 购 ， 将 图 书 
信息 按 类 别 展 现 出 来 。 用 户 在 选 购 图 书 时 ， 首 先 选择 图 书 大 类 ， 然 后 在 大 类 中 选择 图 书 的 
小 类 ， 这 样 就 可 以 将 该 类 别 的 所 有 图 书 以 分 页 的 形式 展现 出 来 。 明 日 网 上 书店 图 书 分 类 展 
示 效 果 如 图 5.22 所 示 。 
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UDELLEH ES 当前 加 忆 层 次 : 部 谈天 图 所 基本 鱼 J 未 10 市 第 1 页 / 共 1 页 首页 上 一 页 下 一 区 尾 责 
图 5.22 图 书 分 类 展示 效果 
从 图 书 分 类 展示 页 面 可 知 ,浏览 者 可 以 首先 从 网 站 导航 上 方 的 图 书 大 类 中 选择 要 购买 
图 书 的 大 类 ， 然 后 在 子 类 中 选择 具体 语言 类 别 ， 这 样 就 可 以 将 指定 语言 类 别 的 图 书展 现 出 
来 ， 同 时 可 以 按照 指定 的 排列 方式 和 图 书 层次 调整 图 书 显示 顺序 。 下 面 对 明 日 网 上 书店 中 
图 书 分 类 展示 的 实现 过 程 进行 讲解 。 

(1) 创建 listbook.php 文件 实现 图 书 分 类 展示 功能 ， 首 先 使 用 $_GET 全 局 数组 来 接收 
传递 到 页 面 的 排序 方式 标识 、 图 书 层 次 标识 和 当前 要 显示 的 页 码 ， 然 后 使 用 分 页 类 的 
pageData0 方 法 获取 分 页 参数 。 明 日 网 上 书店 实现 按 图 书 类 别 分 页 展示 的 关键 代码 如 下 : 

代码 位 置 ， 配 套 资源 \mr\05\listbook.php 


01 if(!isset($ GET['pltype') ||$_ GET['pltype] =") { // 获 得 图 书 排列 方式 | 
02 S$pltype ="1'; | 
03 J}else{ | 
04 $pltype=$_GET[pltype]: | 
055 | 
06 。 $smarty->assign(pltype'、 $pltype): | 
07 if(!isset($ GET['cctype']) ||$ GET['cctype] —") { // 获 得 图 书 层次 标识 | 
08 Scctype="1': | 
09 J}else{ | 
10 $cctype=$_GET[cctype]: | 
4 } ! 
12 $smarty->assign('cctype’. $cctype): | 
13 if(!isset($ GET['page']) ||$ GET['page] =—=") { // 获 得 当前 要 显示 的 页 码 | 
14 Spage= "1'; | 
15 }else{ | 


。191 。 \ 
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Spage=$ GET[page]: 


} 

$smarty->assien('page’. $page): 

$smalltype = $adminDB->executeSQL("select id bigtypeid. typename from 
tb_smalltype where id='$stid". $connID); // 查 询 图 书 小 类 


$smarty->assign('smalltype’. $smalltype): 
Sbigtype = $adminDB->executeSQL("select id typename from tb_bigtype 
where id=" . $smalltype[0][bigtypeid] . "", $connID); 
$smarty->assign(bigtype' $bigtype): 
$smalltypes = $adminDB->executeSQL("select id typename from tb smalltype 
where bigtypeid=" . Sbigtype[0]['id] . "". SconnID): /查询 图 书 大 类 
S$smarty->assien('smalltypes'. $smalltypes): 
if ($cctype —'1) { /设置 图 书 层 次 条 件 
$where=" and smalltypeid =" . $stid . "": 
} elseif ($cctype 一 '2){ 
$where=" andbookcc= 1 and smalltypeid = " . $stid . "": 
} elseif ($cctype —'3") { 
S$where =" and bookcc =2 and smalltypeid=". $stid . "": 
} elseif ($cctype == "4) { 
S$where =" andbookcc=3 and smalltypeid=". $stid . "": 
} 
if (Spltype —'1) { // 设 置 图 书 排列 方式 
S$order = "addtime desc"; 
} elseif ($pltype —'2) { 
S$order = "pubtime desc"; 
} elseif ($pltype — '3") { 
S$order = "newprice asc"; 
} elseif ($pltype — "4) { 
S$order = "browsertime desc"; 


} 


$sql = "select tb bookinfo.id, tb bookinfo.bookimg, tb bookinfo.oldprice, tb bookinfo. 


tb bookinfo.about. tb bookinfo.browsertime， tb bookinfo.bookname, tb bookinfo.writer, 
tb_bookinfo.pubtime, 


48 tb_bookinfo.addtime, tb_bookinfo.ishave, tb_pub.pubname from tb_bookinfo, tb pub where 
tb_bookinfo.pubid = 

49 tb pub.id".$where." orderby".$order."™: // 构 建 查询 语句 

50 $bookinfos= $pageDB->pageData($sql, $connID, 10, $page): // 执 行 分 页 查询 

SL $smarty->assien(‘bookinfos'. $bookinfos): 


(2) 获得 图 书 分 页 信息 数组 后 ， 还 需要 建立 视图 模板 文件 来 显示 分 页 内 容 ， 
listbook.phtml 视图 文件 中 ， 通 过 section 标签 显示 分 页 数据 ， 其 关键 代码 如 下 : 


代码 位 置 ， 配套 资 源 \mr\05\Wiews\listbook.phtml 


01 
02 


{if $bookinfos.countRs > 0} 
{section name=pbID loop=$bookinfos.data} 
<div style="width:930px"> 

<br> 

<div style="width:100%: height:180px"> 
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06 <div style="width:20%: height:100%%: float:left"> 

07 <a href=" {util->baseUrl}/bookinfo- {$bookinfos.data[pbID].id} html"> 

08 <img src="{$system[0].bookimgurl}/{$bookinfos.data[pbID].bookimg}" 

09 width="110" height="150" style="border:1px solid #123456" /></a> 

10 </div> 

bs <div style="width:78%; height:100%%; float:right: text-align:left: font-size: 13px"> 

1 <li style="display:inline"><a href=" {util->baseUrl}/bookinfo- {$bookinfos.data 
[pbID].id} .html" 

13 class="a$"><stroneg>{$bookinfos.data[pbID].bookname}</strong></a></li> 

14 <br><br> 

15 <li style="display:inline"> 出 版 社 : {$bookinfos.data[pbID].pubname}</li> 

16 <br><br> 

17 <li style="display:inline"> 作 者 : {$bookinfos.data[pbID].writer}</li> 

18 <br><br> 

19 <li style="display:inline"> 上 架 时 间 : 

20 {$bookinfos.data[pbID].addtimeltruncate:10:""} &nbsp:é&nbsp;&nbsp:&nbsp:&nbsp;&nbsp: 出 版 时 间 : 

21 {$bookinfos.data[pbID].pubtimeluncate:10:""} &nbsp:&nbsp:&nbsp;&nbsp:&znbsp:&nbsp: 浏 览 次 数 ; 

22 {$bookinfos.data[pbID].browsertime}&nbsp:; 次 </li> 

23 <br><br> 

24 <li style="display:inline"> 市 场 价 : 

25 <img src="{util->baseUrl}/img/mark green.gif' />&nbsp:<s> 

26 {util->moneyFormatp=$bookinfos.data[pbID].oldprice}</s> 

27  &nbsp:é&nbsp;&nbsp:énbsp;&nbsp:énbsp;é&nbsp:énbsp:;&nbsp:é&nbsp;&nbsp;é&nbsp: 

28 <font color="#EF0000"> 会 员 价 : <img src=" {util->baseUrl}/img/mark_red.gif" />&nbsp; 

29 {util->moneyFormatp=$bookinfos.data[pbID].newprice}</font> 

30 </> 

SL <br><br> 

32 <li style="display:inline"><a href=" {util->baseUrl}/cart-{$bookinfos.data [pbID].id} 
-add.html"> 

33 ”<img sre=" {util->baseUrl}/img/button order.gif" border="0"/></a>&nbsp:&nbsp:&nbsp: &nbsp: 

34 <ahref="{util->baseUrl}/bookinfo-{$bookinfos.data[pbID].id}.html"> 

35 <img src="{util->baseUrl}/img/button info.gif" border="0"/></a></li> 

36 </div> 

37 </div> 

38 <div style="width:95%; height:50px: border:1px solid #CCCCCC: 

39 text-align:left: line-height:18px: color:#990000: padding:Spx"> 

40 {util->unHtml p=$bookinfos.data[pbID].aboutltruncate:420:"...":false} 

41 </div> 

42 </div> 

43 {/section} 

44 {else} 

45 <div style="width:500px: height:80px: font-size:14px: color:#FF0000"> 

46 <img src=" {util->baseUrl}/img/mark telllogin.gif'><br /> 

47 <strong> 对 不 起 ， 暂 无 该 类 图 书 ! </strong> 


“gs 


| 邹 


48 </div> 
49 。{/ 刘 


为 了 满足 不 同 用 户 的 需要 ， 在 制作 明日 网 上 书店 过 程 中 ， 网 站 根据 需求 设置 了 特别 图 
书展 示 模 块 。 特 别 图 书展 示 模 块 可 以 对 新 书 、 特 价 图 书 、 热 卖 图 书 和 期 书 实现 分 页 展示 ， 
| 其 运行 效果 如 图 5.23 所 示 。 


首页 靳 价 扼守 本 书 斌 着 
0 长 器 市 明日 科技 书店 。 (qos 一 一 > i 
wmrpocksin DBMmir ECEE | 


| 数 氢 庄 | 辣 交 半径 | 全 作 下 绞 ， 本 本 读 计 


| 程序 设计 


网 结 


3M' 信 | 办公 款 件 | 去 全 | 考试 认可 | 多 径 体 | 病 讶 与 养护 | 其 他 


您 当前 的 位 置 ， 明日 网 上 书店 >》 新 书 按 存 
新书 挫 荐 共 7 本 专 了 I 吕 示 10 不 第 1 U1 了 上 一 且 下 一 NH NEI 
《C8 程序 设计 标准 稚 程 } 
本 出 版 诗人 民 妥 所 出 版 坟 
[ses 作者 明日 和 扩 王 小 和 B 双 
~ 上 当时 间 :2009-0T-03 


作 场 作 : 本 88r66 


WA 

志 书 只 初学 上 和 喀 出 站 ， 户 这 请 从 好 全 六 光大 量 相 动 和 下 实 介 ， 条 深入 所 、 三 六 尘 法 介绍 他 且 Ci on 站 开放 尼 村 本 万 法。 他 基部 宇 。 1 
第 ]0 章 主要 介绍 LiRwiax cy cy 天 丰 ，ry 河 名 从 制 ， 光 这 ， 面 对象 六 程 ， 天 fiagsre: 应 用 各 ,mixEerv: 罕 信介 绍 ， ivrws 到 用 程序 开发 有 从 
件 ， 生 香 栏 、 了 具 栏 和 关 交 设计 及 对 三 等 内 容 ; 第 1 盖 第 20 吾 主要 方 便 用 407 了 ET 接 作 数 床 ,文件 处 于 技术 ，ic 了 和 炒作，5D+ 


《ASF .NET 网 结 编 程 标准 教程 》 


RSRNET 出 版 社 ， 人 民 部 四 出 肯 社 


标准 教科 作者 张 联 延 丁 打 兵 
加 二 加 时间: 2009-07-03 出 版 时 间 ，2009-03-00 。。 PS2% 妇 ，s20 次 
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图 5.23 新 书展 示 
了 解 明日 网 上 书店 特别 图 书展 示 的 运行 效果 后 ， 下 面 将 详细 介绍 该 模块 的 实现 过 程 。 
(1) 建立 listsepbook.php 文件 用 来 实现 业务 逻辑 。 在 该 文件 中 ， 首 先 使 用 $_GET 全 


代码 位 置 ， 配套 资源 \mr\05\listsepbook.php 


| 

| 

| 01 <?php 

| 02 Tequire_once (headerphp): 

| 03 if($_GET[t]=—='new’) { 1/ 接收 查询 字符 串 t 的 值 
| 04 Snowtype = ' 新 书 推荐 ': 

| 05 $andwhere = "isnew = 1"; 

| 06 。 } elseif($_GET[Y] 一 'sepprice) { 

| 07 Snowtype = 特价 图 书 ': 

| 08 $andwhere = "issepprice = 1"; 

| 09 } elseif ($_GET[t] 一 "hotsell) { 

j 。194。 
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10 

11 

12 }elseif($ GET[t]—'term') { 

13 Snowtype = ' 期 书 : 

14 $andwhere = "isterm = 1"; 

15 jelseif($ GET[I] 一 'mrbook) { 
16 Snowtype =' 明 日 图 书 推荐 ": 
A Sandwhere = "ismrbookt = 1": 
18 } 


19 $smarty->assign('gt, $ GET[T]): 

20 $smarty->assign(‘nowtype'. Snowtype): 

21 $system = $adminDB->executeSQL("select bookimgurl, readurl from tb_system where mark = ， 
1", $connID): 


22 $smarty->assign('system', $system): // 查 询 系统 配置 信息 
23 if(!isset($ GET['page') ||$ GET[page] 一 "){ // 获 得 当前 页 面值 
24 Spage="1'; 

25 } else { 

26 Spage =$_GET['page']: 

27 } 


28 $sql = "select tb bookinfo.id, tb_bookinfo.bookimg. tb_bookinfo.about, tb_bookinfo. | 
browsertime, | 
29 tb_bookinfo.oldprice, tb_bookinfo.newprice, tb_bookinfo.bookname, tb_bookinfo.writer, tb_ ,| 
bookinfo.pubtime, | 
30 tb_bookinfo.addtime, tb_bookinfo.ishave, tb_pub.pubname from tb_bookinfo, tb_pub | 
31 where tb bookinfo.pubid=tb pub.id and " . Sandwhere . " order by tb_bookinfo.addtime desc"; ,| 
/构建 查询 语句 | 
32 $bookinfos= $pageDB->pageData($sql, $connID, 10, $page): // 实 现 分 页 查询 | 
33 $smarty->assign(bookinfos', $bookinfos); 
34 $smarty->display('listsepbook.phtml"): 
35 Tequire_once ‘footer.php'; 


(2) 获得 分 页 数据 后 ， 就 可 以 在 views 模板 文件 目录 中 的 listsepbook.phtml 文件 中 ， 
通过 section 标签 将 图 书信 息 分 页 显示 出 来 ， 其 关键 代码 如 下 : 
代码 位 置 ， 配套 资源 \mr\05\views\listsepbook.phtml 


01 {if $bookinfos.countRs > 0} | 
02 {section name=pbID loop=$bookinfos.data} | 
03 <div style="width:930px"> | 
04 <br> | 


05 <div style="width:100%%; height:180px"> 
06 <div style="width:20%: height:100%%: float:left"> 
07 <a href=" {util->baseUrl}/bookinfo- {$bookinfos.data[pbID].id}.html"> 


08 <img src="{$system[0].bookimgurl}/ {$bookinfos.data[pbID].bookimg}" 
09 width="110" height="150" style="border: 1px solid #123456" /></a> 


10 </div> 

11 <div style="width:78%: height:100%;: float:right: text-align:left: font-size:13px"> 

12 <li style="display:inline"><a href=" {util->baseUrl}/bookinfo- {$bookinfos.data 
[pbID].id} .html" 


13 class="a5"><strong>{$bookinfos.data[pbID].bookname}</strong></a></li> 


“00s 


23 
24 


25 
26 
| 2 
| 28 
| 29 
| 30 
| 31 
| 32 
| -add.html"> 
| 33 
| &nbsp: 
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<li style="display:inline"> 出 版 社 : {$bookinfos.data[pbID].pubname}</li> 
<br><br> 
<li style="display:inline"> 作 者 : {$bookinfos.data[pbID].writer}</li> 
<br><br> 
<li style="display:inline"> 上 架 时 间 : 
{S$bookinfos.data[pbID].addtimeltruncate:10:""}&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp: 出 


{$bookinfos.data[pbID].pubtimeltruncate:10:""}&nbsp:é&nbsp:&nbsp:&nbsp:&nbsp:;&nbsp: 浏 


{$bookinfos.data[pbID].browsertime} &nbsp: 次 </li> 

<br><br> 

<li style="display:inline"> 市 场 价 : 
<img src=" {util->baseUrl}/img/mark green.gif" />&nbsp: 
<s> {util->moneyFormatp=$bookinfos.data[pbID].oldprice}</s> 

<font color="#F0000"> 会 员 价 : 
<img src=" {util->baseUrl}/img/mark red.gif" />&nbsp: 
{util->moneyFormat p=$bookinfos.data[pbID].newprice}</font> 
<> 
<br><br> 
<li style="display:inline"><a href=" {util->baseUrl}/cart-{$bookinfos.data[pbID].id} 


<img src="{util->baseUrl}/img/button order.gif’ border="0"/></a>&nbsp:é&nbsp;&nbsp; 


<a href=" {util->baseUrl}/bookinfo-{$bookinfos.data[pbID].id} .html"> 
<img src=" {util->baseUrl}/img/button_info.gif" border="0"/></a></li> 
</div> 
</div> 
<div style="width:95%; height:S0px: border: 1px solid #CCCCCC: 
text-align:left: line-height: 18px; color:#990000: padding:5px"> 
{util->unHtml p=$bookinfos.data[pbID].aboutltruncate:420:"...":false} 
</div> 
</div> 
{/section} 
{else} 
<div style="width:500px: height:80px: font-size:14px: color:#FF0000"> 
<img src=" {util->baseUrl}/img/mark telllogin.gif'><br /> 
<strong> 对 不 起 ， 暂 无 新 书信 息 ! </strong> 


</div> 
{ 诊 


5.6.3 ”图 书 试 读 展 示 


为 了 能 够 让 读者 了 解 某 本 图 书 的 大 概 内 容 ， 
书店 时 ， 将 图 书 试 读 作为 单独 模块 陈列 ， 其 运行 效果 如 图 5.24 所 示 。 


吸引 更 多 读者 购买 图 书 ， 在 制作 明日 网 上 
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图 5.24 ” 试 读 图 书展 示 


通过 明日 网 上 书店 的 图 书 试 读 模块 ， 可 以 将 带 有 试 读 信息 的 图 书 搜集 到 一 起 ， 并 通过 

分 页 的 形式 展现 出 来 ， 下 面 将 具体 讲解 试 读 图 书 分 页 展示 的 实现 方法 。 
(1) 首先 通过 $_GET 全 局 数组 接收 查询 字符 串 page 的 值 ， 该 值 用 来 指定 当前 页 面 要 
显示 的 内 容 ， 然 后 构建 查询 语句 ， 通 过 分 页 类 的 pageData0 方 法 获得 分 页 数据 ， 并 通过 
Smarty 模板 引擎 的 assign0 方 法 指派 给 视图 变量 ， 其 中 listreadbook.php 文件 的 具体 实现 代 


码 如 下 : 


代码 位 置 ， 配 套 资源 \mr\05\listreadbook.php 


01 Tequire_once (‘header.php"): 

02 ”Snowtype =' 图 书 试 读 下 载 ': 

03 $smarty->assign('nowtype', Snowtype): 

04 $system = $adminDB->executeSQL("select bookimgurl readurl from tb_system where mark = 
1", $connID): 

05 $smarty->assign('system', $system); // 查 询 系 统 配 置信 息 

06 if(!isset($ GET['page'])||$ GET[page] 一 7){ /获取 当前 页 码 

07 Spage="1'; 

08 }else{ 

09 Spage=$ GET['page']: 

TO 

Eh! $sql = "select tb_bookinfo.id, tb_bookinfo.bookimg, tb_bookinfo.oldprice. tb_bookinfo. 
newprice, 

12 tb_bookinfo.about. tb_bookinfo.browsertime. tb_bookinfo.bookname. tb_bookinfo.writer tb_ 
bookinfo.pubtime. 

13 tb_bookinfo.addtime. tb_bookinfo.ishave. tb pub.pubname. tb read.id as readid. tb read. 
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MNote 


fename from 


14 
15 
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tb_bookinfo, tb_pub. tb_read 
where tb bookinfo.pubid = tb pub.id and tb read.bookinfoid = tb bookinfo.id order by 


tb_read.addtime desc": 


16 
Lif 
18 
19 


$bookinfos = $pageDB->pageData($sql, $connID, 10. $page): 。“ // 执 行 分 页 查询 
$smarty->assign('‘bookinfos'. $bookinfos): 

$smarty->display('listreadbook.phtml"):; 

Tequire_once 'footerphp': 


| (2) 在 listreadbook.php 页 面 ， 通 过 Smarty 模板 引擎 的 assign0 方 法 为 视图 变量 赋值 
| 后, 就 可 以 在 
实现 代码 如 下 : 


代码 位 置 : 


[pbID].id} .html" 
13 
14 
15 
16 
好 
18 
19 
20 
版 时 间 : 
21 
览 次 数 : 
22 
23 
24 
/>&nbsp: 
25 
26 
2 
28 
29 
30 


listreadbook.phtml 模板 文件 中 通过 section 标签 遍历 图 书信 息 并 显示 出 来 , 其 


配套 资源 mr\0Svviewslistreadbook-phtml 


{if $bookinfos.countRs > 0} 
{section name=pbID loop=$bookinfos.data} 
<div style="width:930px"> 
<br> 
<div style="width:100%:; height:180px"> 

<div style="width:20%; height:100%: float:left"> 

<a href=" {util->baseUrl}/bookinfo- {$bookinfos.data[pbID].id} .html"> 

<img src="{$system[0].bookimgurl}/ {$bookinfos.data[pbID].bookimg}" 
width="110" height="150" style="border: 1px solid #123456" /></a> 

</div> 

<div style="width:78%; height:100%; float:right:; text-align:left; font-size:13px"> 
<li style="display:inline"><a href=" {util->baseUrl}/bookinfo-{$bookinfos.data 


class="a5"><strong>{$bookinfos.data[pbID].bookname}</strong></a></li> 

<br><br> 

<li style="display:inline"> 出 版 社 : {$bookinfos.data[pbID].pubname}</li> 

<br><br> 

<li style="display:inline"> 作 者 : {$bookinfos.data[pbID].writer}</li> 

<br><br> 

<li style="display:inline"> 上 架 时 间 : 

{$bookinfos.data[pbID].addtimeltruncate:10:""}&nbsp:é&nbsp:é&nbsp:&nbsp:&nbsp:&nbsp: 出 


{Sbookinfos.data[pbID].pubtimeltruncate:10:""}&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp: 浏 


{$bookinfos.data[pbID].browsertime} &nbsp; 次 </li> 
<br><br> 
<li style="display:inline"> 市 场 价 : <img src=" {util->baseUrl}/img/mark_green.gif" 


<s>{futil->moneyFormatp=$bookinfos.data[pbID].oldprice}</s>&nbsp:&nbsp:&nbsp:&nbsp: 
<font color=-"#EF0000"> 会 员 价 ; <img src="futil->baseUrlj/img/mark red.gif' />&nbsp: 
{util->moneyFormat p=$bookinfos.data[pbID].newprice}</font> 
</> 
<br><br> 
<li style="display:inline"><a href="{util->baseUrl}/cart-{$bookinfos.data 


[pbID].id}-add html"> 
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31 <img src=" {util->baseUrl}/img/button order gif' border="0"/></a> 

32 &nbsp:&nbsp:&nbsp:&nbsp:<a 
href=" {util->baseUrl}/bookinfo- {$bookinfos.data[pbID].id} html"> ! 

33 <img src="{util->baseUrl}/img/button info.gif' border="0"/></a>&nbsp:&nbsp:; ， 
&nbsp;é&nbsp; 

34 <ahref=" {$system[0].readurl}/download.php?rid={$bookinfos.data[pbID].readid} 

35 &filename={$bookinfos.data[pbID].filename}"> 

36 <img src=" {util->baseUrl}/img/button_sdcz.gif" border="0"/></a></li> 

37 </div> 

38 </div> 


39 <div style="width:95%; height:S0px: border:1px solid #CCCCCC: 
40 text-align:left: line-height:18px: color#990000: padding:5px"> 
41 {util->unHtml p=$bookinfos.data[pbID].aboutltruncate:420 


false} 


42 </div> 
43 <div> 
44 {/section} 
45 {else} 


46 <div style="width:500px:; height:80px: font-size:14px; color:#FF0000"> 
47 <img src="{util->baseUrl}/img/mark telllogin.gif’><br /> 


48 <strong> 对 不 起 ， 暂 无 新 书信 息 ! </strong> 
49 </div> 
50 {二 


5.6.4 图 书 详细 信息 展示 


前 面 详细 介绍 了 图 书 按 各 种 特点 进行 分 页 展示 的 实现 过 程 ， 为 了 能 够 更 加 细致 地 了 解 
所 查询 图 书 的 详细 信息 ， 并 能 够 对 所 选 购 的 图 书 进行 评论 ， 网 上 书店 还 需要 通过 图 书 详细 
信息 页 将 图 书信 息 展现 出 来 ， 效 果 如 图 5.25 所 示 。 


EEC 


书 名 : 《P 亚 开发 拱 于 模 志 大全》 

出版 社 ， 人 民 师 让 出 产 社 JR 610 (可 
字 ， 1157 ( 千 字 ) 
全 届 疡 次 ， 41 
国 书 尖 和 :PHP 


全 上 二 查看 大 加 


书 详细 信息 展示 
明日 网 上 书店 的 图 书 详细 信息 页 面 主要 用 于 实现 图 书 详细 信息 的 展示 、 组 合 购买 图 书 
“99s 
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的 推荐 和 图 书评 论 等 功能 ， 下 面 将 对 实现 上 述 功能 的 关键 代码 进行 讲解 。 


| (1) 获 


区 图 书 详细 信息 并 将 获取 的 信息 显示 在 页 面 中 。 首 先 通过 $_GET 全 局 数组 接 


| 收 查询 字符 串 bid 的 值 ， 其 中 bid 代表 传递 到 该 页 面 的 ID 号 ， 并 将 图 书 ID 保存 到 
$arrayBrowserID 数组 中 ， 该 数组 用 于 保存 当前 用 户 所 浏览 的 图 书 ID， 然 后 构建 查询 语句 

| 并 使 用 数据 库 管 理 类 的 executeSQL(0 方 法 执行 查询 ， 获 取 指 定 ID 的 图 书信 息 ， 其 具体 操 
Mote | 作 在 bookinfo php 文件 中 完成 ， 关 键 代码 如 下 : 


| 代码 位 置 : 配套 资源 \mr\05\bookinfo.php 

| 01 require once 'header.php'; 

| 02 if(isset($ GET[bid]) &&S$ GET[bid] (=") { // 获 得 查询 字符 串 bid 的 值 

| 03 $bid =$_GET['bid"]: 

| 04 J}elsef{f 

| 05 S$bid=$_POST[bid]: 

| 06  } 

| 07 $smarty->assign('bid'. $bid); 

| 08  @$adminDB->executeSQL("update tb bookinfo 

| 09 set browsertime = browsertime+l Where id=" . $bid . "",$connID); // 更 改 图 书 被 浏览 的 次 数 
| 10 if(isset($_SESSION['browserIDs']) &é& $ SESSION['browserIDs] (=") { /设置 用 户 浏 
| 览 过 图 书 ID 

| 11 $arrayBrowserID = explode('@'. $_SESSION['browserIDs']): 

| 2 Sflag = 0; 

| 13 for ($i= 0: $i < count($arrayBrowserID): $i++) { 

| 14 if ($arrayBrowserID[$i] := " && $arrayBrowserID[$i] 一 $bid) { 

| 15 Sflag = 1: 

| 16 } 

| 17 } 

| 18 if($flag = 0) { 

| 19 ©@ $_SESSION['browserIDs'] = $bid . '@; 

| 20 

| 21 } else{ 

| 22 $_SESSION['browserIDs'] = $bid . '@': 

| 3 

| 24 $arrayBrowserBookids = explode(@'$ SESSION[browserIDs]): 

| 2 $arrayBrowserBooks = arrayO: 

| 26 for ($i= 0: $i < count($arrayBrowserBookids): $i ++) { 

| wh if ($arrayBrowserBookids[$i] != ") { 

| 28 $tmpBookinfo = $adminDB->executeSQL("select id. bookname. bookimg from 


tb_bookinfo where id=" . $array BrowserBookids[$i] . "". $connID): 


| 2 array_push($arrayBrowserBooks, StmpBookinfo): 
30 加 

| 31 } 

| 32 $smarty->assign('arrayBrowserBooks', $arrayBrowserBooks): 

| 33 if(!isset($_ GET['cctype') ||$ GET['cctype] =—=") { 1/ 获取 图 书 层次 类 别 标识 

| 34 if(isset($ POST[cctype]) &&S POST[cctype] !=") { 

| 35 S$cctype= $_POST[cctype]: 

| 36 }else{ 

| 37 $cctype= "1': 

| 38 } 

| 


"200 


39 }else{ 

40 Scctype = $_GET['cctype']:; 

a 

42 $smarty->assign('cctype'. $cctype): 

43 S$bigtypes = $adminDB->executeSQL("select id typename from tb_bigtype order by addtime", 
$connID): 

44 $smarty->assign('bigtypes'. $bigtypes): // 查 询 图 书 大 类 

45 $smalltypes = $adminDB->executeSQL ! 

46 ("selectid, typename, bigtypeid from tb_smalltype order by addtime", $connID); /查询 | 
图 书 小 类 

47 $smarty->assign('smalltypes', $smalltypes): 

48 $bookinfo= $adminDB->executeSQL("select tb bookinfo id as bid, bookname, bookids, page. 
isbn, zs, bookcc, bc, 

49 about, directory, writer, pubname, pubtime, bookimg. typename, oldprice, newprice 

50 from tb bookinfo. tb pub., tb_smalltype 

51 where tb_bookinfo.pubid = tb_pub.id and tb_bookinfo.smalltypeid = tb_smalltype.id 

52 and tb_bookinfo.id=" . $bid . "", $connID); // 获 得 图 书信 息 

53 $smarty->assign('‘bookinfo', $bookinfo): 
Ah 关键 代码 解析 


@ 这 里 将 用 户 所 浏览 过 的 图 书 ID 用 字符 “@” 作 为 分 隔 符 连 接 保存 到 session 中 。 
加 函数 array_pushO 用 来 将 元 素 添加 到 指定 的 数组 中 。 
(2) 为 了 帮助 读者 选 购 套 系 图 书 ， 制 定 学 习 流 程 ， 在 制作 明日 网 上 书店 图 书 详细 信 
息 页 时 , 增加 了 图 书 组 合 购买 功能 , 从 而 对 读者 学 习 起 到 借鉴 作用 , 其 效果 如 图 5.26 所 示 。 


图 5.26 图 书 组 合 购买 


在 数据 库 中 使 用 tb_book 表 的 bookids 字段 将 组 合 购买 图 书 ID 用 字符 “@ ”连接 ， 在 
bookinfo.php 页 面 中 首先 使 用 函数 explode0 将 组 合 ID 保存 到 数组 中 ， 然 后 使 用 for 循环 语 
句 遍 历 该 数组 ， 根 据 该 数组 元 素 查 询 出 所 有 组 合 图 书信 息 并 将 图 书信 息 保存 到 
$arrayZhBooks 数组 中 ， 最 后 将 该 数组 传递 给 模板 ， 在 模板 中 通过 section 标签 显示 所 有 组 
合 图 书 的 信息 ， 其 中 用 于 实现 上 述 功能 的 代码 如 下 : 

代码 位 置 ， 配 套 资源 \mr\05\bookinfo.php 


01 
02 
03 
04 
05 
06 


$arrayBookids = explode('@'. $bookinfo[0][bookids]): /使 用 字符 “@” 分 割 组 合 图 书 ID 
$arrayZhBooks = array(); 
$zhIDs = $bookinfo[0][bid] .@': 
for ($i= 0: $i < count($arrayBookids): $i++) { /获得 组 合 ID 图 书信 息 
if ($arrayBookids[$i] !=") { 
$tmpBookinfo = $adminDB->executeSQL("select id. bookname. bookimg from 
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tb bookinfo where id=" . $arrayBookids[$i] . "", $connID): 
array_push($arrayZhBooks, StmpBookinfo): 
$zhIDs = $tmpBookinfo[0l[id] .'@': 
} 
$smarty->assign(zhIDs'. $zhIDs): 
$smarty->assign('arrayZhBooks'. $arrayZhBooks): 


| (3) 在 图 书 详细 信息 页 加 入 读者 评论 功能 ， 有 助 于 网 站 经 营 者 分 析 图 书 的 价值 ， 从 
| 而 确定 图 书 在 站 点 中 的 摆 放 位 置 ， 其 中 ， 明 日 网 上 书店 中 用 户 实现 图 书评 论 的 文件 
| bookinfo.php 的 关键 代码 如 下 : 

| ”代码 位 置 : 配套 资源 mi\05\bookinfo.php 


01 

02 
$connID)) { 
03 

04 

05 

06 

| 07 
| 08 
| 09 
| 10 
11 

| 到 
| 13 
| 14 
| 15 
| 16 
7 

| 18 
| 19 
| 20 
| 2 
22 

| 23 
| 24 
| 25 
| 26 
27 

| 28 
| 29 
| 30 
| 31 
| 52 
3 


if (isset($ GET['did]) && $ GET[did] 二 7){ /删除 评论 信息 
if (! $adminDB->executeSQL("delete from tb pl where id=" . $ GET[did] . ™", 


echo "<script>alert( 评 论 删除 失败 !");</script>"; 
}else{ 

echo "<script>alert( 评 论 删除 成 功 !"):</script>"; 
} 


} 
if (isset($_ POST['content]) && $ POST['content] (= ") { 
if (isset($_SESSION["unc'])) { // 获 得 评论 人 信息 
S$unc =$_SESSION[unc']; 
} else{ 
$unc = ' 匿 名 ': 
} 
if (! $adminDB->executeSQL("select id bookinfoid from tb_pl 
Where bookinfoid=" . $bid . " and content=" . $_ POST['content] . "". $connID)) { 
if ($adminDB->executeSQL("insert into tb_pl(bookinfoid., content, addtime, usernc, ip) 
Values(" . $bid.", ".$ POST['content] . "." . date('Y-m-d H:i:s) .™," . $unc .™", 


™.$_ SERVER[REMOTE ADDR'] .")",SconnID)){ /保存 评论 信息 
echo "<script>alert( 评 论 发 表 成 功 !):</script>"; 
}else{ 
echo "<script>alert(' 评 论 发 表 失败 !):</script>"; 
} 
} 
} 


$pls = $adminDB->executeSQL("select id content, usernc, addtime, ip from tb_pl 

Where bookinfoid=" . $bid . " order by addtime desc". SconnID): /查询 该 书 所 有 评论 
$smarty->assign('pls', $pls): 

if($pls) { // 获 得 评论 总 数 
Stotalp] = count($pls): 

}else{ 

S$totalpl = 0: 


} 
$smarty->assign('totalpl'. $totalp)): 


| 上 述 代码 主要 实现 图 书评 论 的 删除 、 保存 和 展示 等 功能 。 在 实现 删除 图 书评 论 功 能 时 ， 
| 首先 通过 $_GET 全 局 数组 接收 要 删除 评论 的 了 D 号 ,然后 使 用 数据 库 管理 类 中 executeSQLO 


| 方法 执行 删除 操作 。 在 保存 用 户 评论 信息 时 ， 首 先 使 用 isset0 方 法 判断 $_POST['content'] 
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说 
全 局 数组 成 员 是 否 存在 , 如果 存在 则 表明 用 户 已 经 提交 了 评论 表单 ,然后 使 用 executeSQLO 
方法 执行 insert 查询 语句 保存 评论 信息 。 


5.7 图 书 订购 模块 设计 


为 了 方便 读者 购买 图 书 ， 促 进 图 书 销售 ， 在 开发 明日 网 上 书店 时 特别 设立 了 图 书 订 购 
模块 ， 通 过 该 模块 读者 可 以 方便 地 订购 图 书 并 进行 在 线 支付 。 本 节 将 对 明日 网 上 书店 图 书 
订购 模块 进行 讲解 。 

5.7.1 购物 车 的 实现 

购物 车 的 主要 功能 是 保留 用 户 选择 的 商品 信息 。 用 户 可 以 在 购物 车 内 设置 选 购 商品 的 

数量 、 显 示 选 购 商 品 的 总 金额 ， 还 可 以 执行 清除 选择 的 全 部 商品 信息 、 重 新 选择 商品 信息 


等 操作 。 在 5.3.4 节 已 经 对 购物 车 类 的 实现 过 程 进行 了 详细 讲解 ， 下 面 将 在 此 基础 上 介绍 
购物 车 的 页 面 设计 和 其 功能 的 实现 过 程 。 明 日 网 上 书店 的 购物 车 运行 效果 如 图 5.27 所 示 。 


Da DD sms 
4 BD wus 记 i Te 


和 购物 流 履 


国 书 名称 市 场 从 5 殉 ) 
《pip 开发 和 了 模块 大 全 》 mm 
《yisunl CH 开发 缀 区 技巧 室 则 》 -m0 


堆 二 了 0 物 | 清空 9 和 


图 5.27 购物 车 
了 解 购物 车 的 构造 后 ， 下 面 将 在 购物 车 类 的 基础 上 具体 讲解 购物 车 各 个 功能 的 实现 过 程 。 
(1) 购物 车 中 商品 的 增 、 删 、 改 等 业务 逻辑 操作 是 在 cartphp 文件 中 实现 的 ,为 了 区 
分 不 同 的 商品 购买 者 ， 可 以 应 用 $_SESSION 全 局 数组 来 保存 商品 ID 串 和 商品 数量 串 ， 所 
以 在 cartphp 文件 的 代码 前 部 应 该 分 别 对 保存 商品 ID 串 和 商品 数量 串 的 $_SESSION 数组 
元 素 进 行 初始 化 设置 ， 其 具体 实现 代码 如 下 : 
代码 位 置 ， 配套 资源 \mr\05\cart.php 
01 ”这 (!isset($_SESSION['idStr]) || !isset($_SESSION[mumstr])) { // 判 断 是 否 设置 商品 人 D 的 


02 $ SESSION[idstr] ="; // 如 果 没 有 则 设置 二 者 ， 并 赋 空 值 
03 $_SESSION[mumstr] =": 
04 


} 
05 Scart=new Cart($ SESSION['idStr'].$_SESSION['numStr"]): // 实 例 购物 车 类 

上 述 代 码 首 先 判 断 用 于 保存 商品 ID 串 的 $_SESSIONT'idStr'] 数 组 元 素 和 保存 商品 数量 
串 的 $_SESSION['mumStr'] 数 组 元 素 是 否 已 经 被 设置 ， 如 果 没 有 设 定 ， 说 明 当 前 用 户 是 第 一 
次 将 商品 添加 到 购物 车 中 ， 则 将 这 两 个 数组 元 素 的 值 设置 为 空 ， 最 后 还 需要 对 购物 车 类 
Cart 进行 实例 化 ， 以 便 继 续 对 购物 车 中 商品 执行 增 、 删 、 改 等 操作 。 
"。203 。 
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(2) 将 商品 添加 到 购物 车 是 通过 购物 车 类 的 addCart0 方 法 实现 的 ， 在 讲解 购物 车 类 

| 时 已 经 介绍 过 相关 方法 的 参数 说 明 ， 该 方法 所 包含 的 两 个 参数 分 别 为 购买 商品 的 ID 和 购 

| 买 商品 的 数量 ,将 商品 成 功 添加 到 购物 车 后 , 还 需要 使 用 购物 车 类 的 gettdstr0 和 getNumstr0 

方法 分 页 获取 经 购物 车 类 处 理 后 的 商品 ID 串 和 商品 数量 串 ， 将 获取 结果 分 别 赋 给 

| $_SESSION 全 局 数组 中 用 于 保存 商品 ID 串 和 商品 数量 串 的 数组 元 素 ， 从 而 实现 购物 车 中 
商品 刷新 效果 ， 实 现 上 述 过程 的 代码 如 下 : 

代码 位 置 ， 配套 资源 mi\05\cart.php 


| 01 这 St 一 'add) // 判 断 当前 操作 类 型 
| 02 《 
| 03 Scart->addCart($_GET['bid", 1); /调用 购物 车 类 的 addCart( 方 法 将 商品 添加 到 购物 车 
| 04 $ SESSION['idStr] = $cart->getIdStrO; /获取 商品 世 串 
05 $_ SESSION[mumstr] = $cart->getNumStr(:; // 获 取 商 品 数量 串 
06 } 


(3) 在 介绍 图 书 详细 信息 页 时 ， 已 经 介绍 过 如 何 将 与 某 本 图 书 相关 的 所 有 图 书 批量 
添加 到 购物 车 的 实现 过 程 ， 其 原理 是 首先 通过 函数 explode0 将 保存 组 合 图 书 ID 的 字符 串 
字符 “@” 分 割 ， 并 将 分 割 结果 保存 到 数组 中 ， 这 样 该 数组 的 每 个 元 素 为 各 本 组 合 图 书 
| 的 ID 号 ,然后 通过 for 循环 遍历 该 数组 , 在 遍历 过 程 中 分 别 通过 购物 车 类 的 addCart0 方 法 
| 将 图 书 添加 到 购物 车 中 ， 上 述 过 程 的 具体 实现 代码 如 下 : 
代码 位 置 ， 配 套 资源 \mr\05\cart.php 


| 

| 

| 

| 

| 01 ”这 St 一 'gAdd) // 济 断 操作 类 型 ， 如 果 为 gAdd 表示 组 合 添加 

| 024 

| 03 SarrayGIds = explode(@',$_GET[ids'); /分 割 组 合 ID 并 将 结果 保存 到 数组 中 

| 04 for($i=0; $i<count($arrayGIds):; $i++) // 遍 历数 组 

| 05 { 

| 06 if($arrayGIds[$i]!=" &é& !in_array($arrayGIds[$i]. explode('@'. $_SESSION['idSt"))) 

| 07 { 

| 08 S$cart->addCart($arrayGIds[$i] .D: /将 每 本 图 书 分 别 添加 到 购物 车 

| 09 } 

| 10 ; 

| 11 $_SESSION['idStr'] = $cart->getIdStrO:; // 重 新 为 商品 ID 串 的 session 变量 赋值 

| 12 $_SESSION['numStr] = $cart->getNumStr0: // 重 新 为 商品 数量 串 的 session 变量 赋值 
is 

| 

| 

| 


(4) 将 指定 的 商品 从 购物 车 中 移出 是 通过 购物 车 类 的 removeCart0 方 法 实现 的 ,该 方 
法 只 包含 要 移出 商品 的 ID 参数， 调用 该 方法 后 ， 再 分 别 为 保存 商品 ID 串 和 商品 数量 串 的 
$_SESSION 全 局 数组 重新 赋值 ， 从 而 实现 刷新 购物 车 的 效果 ， 该 过 程 的 实现 代码 如 下 : 
代码 位 置 : 配套 资源 mr\0svcartphp 


01 ”这 St 一 Yemove) // 判 断 当前 操作 如 果 为 删除 操作 

02 避 国志 

03 S$cart->removeCart($_GET[rbid]):/ 调 用 购物 车 类 的 removeCart0 方 法 删除 指定 的 图 书 
04 $_SESSION['idStr'] = $cart->getIdStrO: 

05 $_SESSION['numStr'] = $cart->getNumStrO); 

06 } 


| 
| 
| 
| 
本 。204 。 
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SS) 
< 


(5) 在 实现 更 改 商 品 数量 功能 时 ， 由 于 商品 数量 由 购买 者 输入 ， 所 以 在 进行 更 新 商 

品 数量 逻辑 前 ， 首 先 应 该 判断 购买 者 输入 的 数字 是 否 合法 ， 如 果 不 合法 则 给 出 提示 ， 并 要 | 

求 用 户 重新 填写 购买 数量 , 成 功 通过 验证 后 , 就 可 以 通过 购物 车 类 的 changNum0 方 法 实现 

更 改 购物 车 中 商品 的 业务 逻辑 ， 该 过 程 的 实现 代码 如 下 : 
代码 位 置 ， 配套 资源 mn\0s\cart.php 


01 
02 


这 St 一 pdate) // 如 果 $t 的 值 为 update， 则 进行 更 新 操作 
{ 

Schangenum =$_GET[mum']: // 获 得 要 更 新 图 书 的 数量 

if!is numeric($changenum) | intval($changenum) <= 0 || floor($changenum)!= $changenum) 

{ // 判 断 数 量 是 否 为 数字 


echo "<script>alert(' 购 买 图 书 的 数量 只 能 为 正 整 数 ! ):</script>": 
Jelse { 
// 调 用 购物 车 类 的 changeNum() 方 法 实现 更 改 数量 
$cart->changeNum($_ GET[ubid]. Schangenum); /购物 车 中 图 书 数 量 
$_ SESSION['idStr] = $cart->getIdStr0: 
$ SESSION[mumstr] = $cart->getNumStr(); 
} 
} 


(6) 清空 购物 车 中 商品 是 通过 购物 车 类 的 setCartNull0 方 法 实现 的 ， 调 用 该 方法 后 再 
重新 为 保存 商品 ID 串 和 商品 数量 串 的 $_SESSION 全 局 数组 赋值 即 可 ， 其 实现 代码 如 下 : 
代码 位 置 ， 配 套 资源 \mr\05\cart.php 


if($t = 'clearAll') // 如 果 $t 为 clearAll 则 表示 进行 清空 购物 车 操作 
{ 
$cart->setCartNull0: /调用 购物 车 类 的 setCartNull0 方 法 清空 购物 车 
$_SESSION['idStr'] = $cart->getIdStrO: 
$_SESSION['numStr'] = $cart->getNumStrO:; 


(7) 完成 购物 车 中 商品 的 增 、 删 、 改 操作 后 ， 还 需要 根据 保存 购物 车 商品 数量 串 的 
$_SESSION['idstr'] 数 组 元 素 从 数据 库 中 查询 出 购物 车 中 各 图 书 的 信息 ， 并 对 每 本 图 书 进行 
价格 小 计 ， 对 购物 车 中 所 有 图 书 的 价格 进行 汇总 ， 具 体 实现 代码 如 下 : 

代码 位 置 ， 配套 资源 \mr\05\cart.php 


01 
02 
03 
04 
05 
06 
07 
08 
09 
10 
hl 
12 
13 
14 
15 


SarrayIds = explode((@'.$ SESSION['idstr]): /分割 商品 ID 串 为 数组 
SarrayNums = explode(@'.$ SESSION[mumstr]): // 分 割 商品 数量 串 为 数组 
SarrayCarInfos = array(): // 保 存 购物 车 信息 的 数组 
S$totalPrice = 0: // 购 物 车 图 书 总 价格 


for($i = 0: $i < count($arrayIds): $i++){ 
S$bookid = $arrayIds[$i]: 
这 $bookid !=") 
{ 
StmpArray = arrayO: 
$bookinfo = $adminDB->executeSQL("select id bookname .oldprice. newprice 
from tb_bookinfo where id=".$bookid."". SconnID); 。“ // 获 得 购物 车 每 本 图 书 的 信息 
$tmpArray['id] = $bookinfo[0]["id']: 
$tmpArray[bookname'] = $bookinfo[0][bookname']: 
$tmpArray['oldprice'] = Sbookinfo[0][oldprice]: 
$tmpArray[mewprice] = $bookinfo[O]['newprice']: 
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16 $tmpArray[mum'] = $arrayNums[$i]: 


3% $tmpArray['smallTotalPrice'] = $bookinfo[0][mewprice'] * $arrayNums[$i]: 

18 @ StotalPrice += $tmpArray['smallTotalPrice']; 1/ 计算 图 书 总 价 

19 array_push(SarrayCarInfos. StmpArray): // 将 每 本 图 书信 息 保存 到 数组 中 
20 } 

21 | 


2 $smarty->assign('arrayCarInfos'. $arrayCarInfos): 
23 $smarty->assign('totalPrice'. $totalPrice): 
24 ifisset($_ SESSION[unc]) &&$ SESSION[unc]'=) 1/ 判断 用 户 是 否 登 录 


25 { 

26 $smarty->assign('isLogin', T’); 
27000 

28 else 

29 { 


30 $smarty->assign('isLogin', 'F"):; 
31 iflisset($_SESSION['toUr1'"])) 


33 unset($_SESSION['toUrI"]): 


} 
35  $_SESSION['toUrl] = 'getbuyuserinfo.html'; 
} 


| < 关键 代码 解析 
@ 代码 中 的 a+=b 相当 于 a=a+b。 


5.7.2 填写 收 货 人 信息 


为 了 能 够 将 用 户 所 购买 的 图 书 顺利 邮寄 到 用 户 手 中 ， 在 用 户 选 择 好 购买 的 图 书后 还 需 
| 要 填写 收 货 人 信息 ， 明 日 网 上 书店 用 于 填写 用 户 个 人 信息 的 页 面 如 图 5.28 所 示 , 在 该 页 面 
| 中 用 户 需 要 填写 个 人 的 真实 信息 、 收 货 方式 等 内 容 ， 如 果 用 户 在 购书 的 同时 需要 发 票 ， 还 
| 需要 填写 发 票 抬头 。 


Nm ye io A 


图 5.28 ”填写 收 货 人 信息 页 面 


"as 
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填写 完 收 货 信 息 并 单 击 “生成 订单 ”按钮 后 ， 用 户 所 填写 的 内 容 将 被 提交 到 | 
getbuyuserinfo.php 文件 中 进行 保存 ， 不 过 需要 注意 ， 这 里 并 没有 直接 将 用 户 填写 的 收获 人 | 
信息 保存 到 数据 库 中 ,而 是 将 这 些 数据 保存 到 $_ SESSION 全 局 数组 中 , 这 样 做 的 目的 是 便 | 
于 用 户 在 订购 过 程 中 适时 对 信息 进行 修改 。 实 现 该 过 程 的 代码 如 下 : | 全 门 
代码 位 置 ， 配套 资源 \mr\05\getbuyuserinfo.php 


01 Tequire_once ‘header.php'; | 
02 让 (isset($_ POST[msername]) && $ POST['username'] !=") { ”// 判 断 用 户 是 否 提交 了 表单 | 


03 $_ SESSION[recuserinfo][username]=$ POST['usemame']: /将 用 户 信息 保存 | 

在 $_SESSION 中 | 
04 $_SESSION['recuserinfo']['sex'] = $_POST['sex']: | 
05 $_ SESSION[Yecuserinfo][address]= $_POST[address]; | 
06 $_SESSION[Yecuserinfo][yb]=$_ POST[yb]: | 
07 $_SESSION[recuserinfo][tel]=$_POST['el]: | 
08 $_SESSION[Yecuserinfo][bz]= $_ POST[bz]: | 
09 $_ SESSION[recuserinfo'][rectype]=$ POST[rectype]: | 
10 $ SESSION[Yecuserinfo][tt] =$ POST[tt]: | 
11 $_SESSION[Yrecuserinfo][unc] = $_ SESSION[unc]: | 
12 $_SESSION[Yecuserinfo][idstr] =$_SESSION[idstr]; | 
13 $_SESSION[Yrecuserinfo][numstr] = $_SESSION[mumstr]; | 
14 Srect = $_POST['rectype']: | 
15 if($rect=—=0|| Srect—='1") { | 
16 Srecpay = "0'; | 
17 } elseif (Srect 一 2 { | 
18 Srecpay = "8"; | 
19 } elseif (Srect —'3') { | 
20 $recpay='20' | 
21 } elseif (Srect —'4') { | 
23 $recpay='30' | 
24 } | 
25 $_SESSION['recuserinfo']['recpay'] = Srecpay: 


26 echo "<script>window.location.href="”" . Sutil->baseUrlO . "/deforder.html';:</script>";// 重 新 定 | 
向 到 deforderhtml 页 面 

2 exit(); 

28 } 

29 $smarty->display('getbuyuserinfo.phtml); 

30 require_once 'footer.php': 


5.7.3 ”确认 订购 信息 


用 户 填 写 完 收 货 人 信息 后 将 进入 订购 信息 确认 页 面 ， 如 图 5.29 所 示 , 在 该 页 面 中 可 以 
查看 并 确认 用 户 所 订购 图 书 的 名 称 、 单 价 、 总 价格 和 收 货 人 的 信息 。 | 
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代码 位 置 : 


01 
02 
数组 中 
03 
保存 到 数组 中 
04 
05 
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图 5.29 确认 订购 信息 页 面 

为 了 更 加 方便 地 实现 图 书 订购 流程 的 业务 逻辑 ， 购 物 车 和 收 货 人 信息 都 分 别 保存 到 
session 中 ， 所 以 查看 用 户 订购 信息 是 通过 将 保存 在 session 中 的 对 应 内 容 提取 并 在 页 面 中 
显示 出 来 实现 的 ， 该 过 程 是 在 deforderphp 文件 中 进行 的 ， 其 实现 代码 如 下 : 


配套 资源 \mr\05\deforder.php 
Tequire_once ‘header.php': 


$arrayIds = explode('@', $ SESSION[Yecuserinfo'][idstr]); ” // 分 割 ID 串 并 将 结果 保存 到 
$arrayNums = explode((Q@'.$_ SESSION[Yrecuserinfo][numstr]): /分 割 数 量 串 并 将 结果 


SarrayCarInfos = array(); // 定 义 数组 用 于 保存 图 书信 息 


StotalPrice = 0: /保存 图 书 总 价 


for ($i= 0: $i < count($arrayIds); $i++) { ”// 通 过 循环 保存 购物 车 中 每 本 图 书信 息 到 数组 


$bookid = $arrayIds[$i]: 
if ($bookid !=") { 
S$tmpArray = array(); 
$bookinfo = $adminDB->executeSQL("select id bookname ,oldprice, newprice 
from tb_bookinfo where id=" . $bookid . "". $connID): 
$tmpArray['id] = $bookinfo[0l['id]: 
$tmpArray["bookname'] = $bookinfo[0][bookname']: 
$tmpArray[mewprice'] = Sbookinfo[0][mewprice]: 
$tmpArray[num'] = $arrayNums[$i]: 
$tmpArray['smallTotalPrice'] = $bookinfo[0][mewprice'] * $arrayNums[$i]: 
StotalPrice += $tmpArray['smallTotalPrice']: 
array_push($arrayCarInfos. StmpArray): 
E 
} 
S$smarty->assign('arrayCarInfos'. $arrayCarInfos): 
$smarty->assign('totalPrice'. $totalPrice): 
$_SESSION['recuserinfo']['bookprice'] = $totalPrice: // 图 书 总 价 
$_SESSION['recuserinfo']['recpayall'] = $totalPrice + $_SESSION['recuserinfo']['recpay']: 
// 图 书 总 价 和 邮递 费 用 
S$smarty->display('deforder.phtml’): 
Tequire_once 'footerphp': 
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5.7.4 选择 支付 方式 | 


用 户 确认 订购 信息 和 收 货 人 信息 无 误 后 ， 就 可 以 选择 支付 方式 了 。 在 明日 网 上 书店 的 支 | 


付 方式 模块 中 ， 主 要 提供 银行 汇款 、 支 付 宝 支付 和 工行 在 线 支付 3 种 方式 ， 其 效果 如 图 530 | 会 内 
所 示 。 ,a 


注 : yr 
Ws i 


“再 it 工 作 找 人 的 让 线 于 拉 口才 线 到 人 
。 而， 用 六 和 避 当 工 条 方 理 同上 行人 
“了 各 时 则 ， 辽 和 时 可 


A 

@ | 
A | 

二 | 
| ET 
A 

图 


图 5.30 选择 支付 方式 页 面 


支付 方式 的 选择 并 不 涉及 复杂 的 业务 逻辑 , 只 需 通过 Smarty 模板 的 display0 方 法 指定 
要 解析 的 模板 即 可 ， 其 实现 代码 如 下 : 
require_once ‘header.php': 
$smarty->display('selectpaytype.phtml'): 
Tequire_once 'footerphp': 


5.7.5 ”确认 支付 信息 | 


选择 支付 方式 后 ， 页 面 会 自动 跳 转 到 图 书 订购 的 最 后 一 个 环节 ， 即 确认 支付 信息 ， 该 页 面 | 
主要 用 于 显示 本 次 图 书 订购 的 订单 号 、 支 付 方式 和 需要 支付 的 总 金额 ， 其 效果 如 图 5.31 所 示 。 


由 区 移入 和 
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图 5.31 确认 支付 页 面 
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确认 订单 主要 用 于 实现 向 数据 库 的 订单 数据 表 中 插入 已 经 存在 于 session 全 局 数组 中 
的 订购 信息 ， 其 实现 代码 如 下 
代码 位 置 ， 配套 资源 \mr\05\defpay.php 


01 
02 


St=$_GET[t]: 

让 (St 一 'qyzh) { // 判 断 支 付 方式 
$paytype = ' 企 业 账 户 汇款 ': 
SalertType = 0" 

} elseif St 一 'ghhk) { 
$paytype=' 工 商 银行 汇款 ' 
SalertType = 0" 

} elseif ($t 一 "hhk’) { 

Spaytype = "建设 银行 汇款 '; 
$alertType = '0: 

} elseif st 一 jyhhk) { 
$paytype = ' 交 通 银行 汇款 ': 
SalertType ="'0": 

} elseif ($t — nhhk’) { 
$paytype = ' 农 业 银行 汇款 ': 
$alertType ="0'; 

} elseif st 一 yiyd){ 

Spaytype =' 邮 局 邮递: 
$alertType ="1': 

} elseif (8t = 'zfb") { 

Spaytype = "支付 宝 在 线 支 付 ': 
$alertType = "2'; 

} elseif (8t =— 'ghzxzf) { 
Spaytype = "工行 在 线 支付 "; 
$alertType = "3'; 


} 

$smarty->assign('alertType', $alertType); 

$ SESSION[recuserinfo'][paytype'] = $paytype: 

S$rectype = $_SESSION['recuserinfo']['rectype']: 

这 ($rectype 一 '0) { // 判 断送 货 方式 
Srt= ' 送 货 上 门 : 

} elseif ($rectype 一 '1){ 
Srt= ' 自 行 取 货 ' 

} elseif (Srectype 一 '2) { 
Srt= ' 平 邮 ': 

} elseif ($rectype 一 '3) { 
Srt= ' 普 通 快递 

} elseif ($rectype 一 '4) { 
$rt='EMS 快递 '; 

} 

if(!isset($_SESSION['recuserinfo']['orderNo']) || $_SESSION['recuserinfo']['orderNo'] ==") { 
$orderNo = date("YmdHis") . mt_rand(1000. 9999): 
$_SESSION['recuserinfo']['orderNo'] = $orderNo: 
if (! $adminDB->executeSQL("insert into tb_order 

(orderno. orderusernc. username. address. sex. yb. tel .tt. idstr numstr. 


“0 
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NS 
47 goodsprice. yjprice, totalprice, rectype, paytype, addtime) 
48 values(" .$ SESSION[YTecuserinfo']['orderNo] . ",".$ SESSION[recuserinfo][unc] . ™. 


49 ".$ SESSION[recuserinfo][usemame].".'" .$ SESSION[Yecuserinfo][address] . " 
50  ".$ SESSION[Yecuserinfo]['sex] . 史 ".$ SESSION[recuserinfo][yb] .", 

51 $_SESSION[recuserinfo][tel] . ". " . $_SESSION['recuserinfo']['tt] . ". 

52 $_SESSION[recuserinfo][idstr] . ". " . $_SESSION['recuserinfo']['numStr] . ". 

53 $ SESSION[recuserinfo][bookprice] . ", " . $ SESSION[Yecuserinfo][recpay] . ", 


54 "S$ SESSION['recuserinfo" [recpayall].™",".$rt.".".S$ SESSION['recuserinfo'] [paytype] . ", 


55 m .date(Ym-d His) .")", $connID)) { /保存 订单 信息 

56 echo "<scripf>alert(' 订 单 保存 失败 !"):</script>"; 

57 } 

58 } else { 

59 if (! $adminDB->executeSQL("update tb order set orderuserc=".$ SESSION 


['recuserinfo'] [unc] . ™, 
60 username=".$ SESSION['recuserinfo']['usermame’].™, 
61 address=".$ SESSION[Yecuserinfo][address] . "sex=" .$_ SESSION[Yecuserinfo][sex] . " 


62 yb=" . $_SESSION['recuserinfo']['yb'] . ". 
63 tel=" . $_SESSION['recuserinfo"]['tel] . ", tt=" . $_SESSION['recuserinfo [tt] "| 
64 idstr=" . $ SESSION['recuserinfo"['idStr] . ", numstr=" . $ SESSION['recuserinfo] | 
[numstr] .", | 


65 goodsprice=" .$_ SESSION[Tecuserinfo'][bookprice'] . ", | 
66 yjprice=".$ SESSION[Yecuserinfo'][recpay] . "， 

67 totalprice=" .$ SESSION[Yecuserinfo'][recpayall] . ", rectype=" . Srt . ", 
68 paytype='" .$_ SESSION[Tecuserinfo'][paytype] . ” | 
69 where ordemo=" .$_SESSION['ecuserinfo[orderNo]."". SconnID)) { /修改 订单 信息 | 
70 echo "<script>alert(' 订 单 修改 失败 ! ):</script>": | 


sa | 

72 if($alertIype='3') { | 

73 SmerInfo = $adminDB->executeSQL("select merid, meracct from tb_system where mark = | 
1", $connID); 


74 $merid = $merInfo[0]['merid"]; | 
75 $meracct= $merInfo[0][meracct]: 

76 $merURL = 'http://www.mrbooks.cn'; 

77 S$orderid=$ SESSION[Yrecuserinfo']['orderNo']: 
78 $nowtime= date("YmdHis"): : 
79 $amount= str replace(',. ". number format($ SESSION['recuserinfo']['recpayall’]. 2)): 
80 $amount= str replace(".", "". $amount): 

81 $amount = str_replace(".", "", $amount); 

82 $src = "ICBC_ PERBANK B2C1.0.0.0". 

83 S$merid . Smeracct . SmerURL . "HS" . $orderid . $amount . "0010" . Snowtime . "0"; 
84 $smarty->assign(orderid'. $orderid): 

85 $smarty->assign(merID' $merid): 

86 $smarty->assign('merAcct', $meracct):; 

87 $smarty->assign(‘amount'. $amount): 

88 $smarty->assign(merURIL' $merURL): 

89 $smarty->assign('‘orderDate'. $nowtime): 

90 $smarty->assign('sre’. $src); 
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| Li elseif ($alertType 一 '2) { 

| 92 $smarty->assign('orderid'. $ SESSION['recuserinfo']['orderNo"]): 

| 93 $smarty->assien('ydType'. EXPRESS"): 

94 $smarty->assien('ydPrice', $_ SESSION[YTecuserinfo'][recpay]): 

95 $smarty->assign('‘bookPrice'. $ SESSION[Yecuserinfo'][bookprice]): 


5.8 后 台 登 录 页 设计 


网 站 的 后 台 模 块 主要 用 于 实现 管理 者 对 网 站 信息 和 注册 用 户 资料 的 管理 过 程 ， 所 以 只 
有 拥有 网 站 管理 权限 的 用 户 才 可 以 登录 ， 为 了 保证 网 站 的 安全 性 ， 这 里 应 用 权限 登录 机 制 
| 来 保证 网 站 的 正常 管理 与 运营 。 后 台 登 录 的 业务 逻辑 在 整个 后 台 管 理 中 显得 尤为 重要 。 


5.8.1 后 台 登 录 页 概述 
| 
| 后 台 首 页 承载 并 显示 网 站 后 台所 包含 的 模块 ， 用 户 需 登录 后 才能 进入 。 下 面 介绍 明日 


| 网 上 书店 后 台 登 录 页 面 的 设计 和 功能 实现 ， 为 了 进一步 提高 网 站 的 安全 性 ， 后 台 登 录 页 面 
| 包含 验证 码 功能 。 明 日 网 上 书店 后 台 登 录 页 面 如 图 5.32 所 示 。 


图 5.32 后 台 登 录 页 


| 5.8.2 ”后台 登录 页 实现 过 程 
明日 网 上 书店 后 台 登 录 页 面 的 制作 过 程 主要 包括 登录 表单 的 设计 和 登录 信息 验证 处 


| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 理 的 业务 逻辑 实现 。 
| 《D 后 台 用 户 登录 表单 的 UT 是 通过 HTML 语言 的 <input> 标 签 实现 的 ， 并 通过 
| JavaScript 实现 图 片 验证 码 ， 其 前 台 模 板 文件 admin-login.phtml 的 实现 代码 如 下 : 
| 代码 位 置 ， 配 套 资源 \mr\05Wiews\admin-login.phtml 

01 <form name="form login" method="post" action=" {util->baseUrl}/admin-login.php" 
| 02 submit="return chkinputadmin(this)"> 

| 03 div style="width:300px: height:200px: text-align:left"> 
| 

| 

| 

| 

| 


04 ”用 户 名 : <input type="text" name="anc" size="22" class="input" /><br /><br /> 
05 密码 : <input type="password" name="pwd" size="22" class="input" /><br /><br /> 
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Bd 
06 验证 码 : <input type="text" name="xym" size="8" class="input" /><input type="hidden" 
name="xym1"> 
07 <script language="javascript"> 
08 var num1=Math.round(Math.random(QO*10000000): 
09 var num=numl.toStringO.substr(0.4): 
10 document.write("<img name=codeimg4 src='xym.php?num="+num.substr(0.1)+">"): 
i document write("<img name=codeimgs sre='xym.php?num="+num.substr(1,1)+">"); 
12 document write("<img name=codeimg6 src='xym.php?num="+num.substr(2,1)+">"); 
document.write("<img name=codeimg7 src='xym.php?num="+num.substr(G3.1)+"> 
14 form login xyml.value=num: 
15 function code 10{ldelim} 
16 Var numl=Math.round(Math random(O*#10000000): 
1 var num=numl .toStringO.substr(0,4): 
18 document.codeimg4.src="xym.php?num="+num.substr(0.1): 
19 document.codeimg5.src="xym.php?num="+num.substr(1,1): 
20 document.codeimg6.src="xym.php?num="+num.substr(2,1); 
21 document.codeimg7.src="xym.php?num="+num.substr(3.1); 
22 form login .xyml.value=num: 
23 {rdelim} 
24 </script> 
25 ”<a href="javascript:code_10" class="al"> 看 不 清 </a> 
26 ”<inputtype="submit" value=" 登 录 " />&nbsp:&nbsp:<input type="reset" valhue=" 重 置 " /> 
27 <div> 
28 </form> 


(2) 用 户 在 登录 页 面 中 输入 用 户 名 、 密 码 和 验证 码 后 ， 单 击 “ 登 录 ” 按 钮 ， 即 可 将 
登录 信息 提交 到 admin-login.php 页 面 进行 业务 处 理 ， 其 实现 代码 如 下 : | 
代码 位 置 ， 配套 资源 unr0svadmin login.php 

01 Tequire_once 'lzh.inc.php'; 

02 这 (isset($_POST[anc]) &&$ POST[anc]!=7){ /判断 用 户 是 否 提交 了 表单 

03 if ($adminDB->executeSQL("select id usernc from tb_user 

04 where usernc=" . $_POST['anc’] . " and 

05 ”pwd=" . md5(trim($ POST[pwd])) . " and usertype=1", $connID)) { ”// 根 据 用 户 昵称 和 | 
密码 查询 管理 员 | 


Value= 


上 述 代码 首先 判断 $_POST['anc'] 的 值 是 否 被 设置 , 如 果 已 经 设置 , 则 说 明 用 户 已 经 提 
“2s 


06 这 (isset($_SESSION['anc])) { // 如 果 查 询 到 则 说 明 登 录 成 功 ， 这 时 将 管理 员 昵 称 保存 | 
到 SESSION 中 | 
07 unset($_SESSION['anc]): | 
08 | 
09 $_SESSION['anc'] = $_POST['anc']; | 
10 echo "<script>window.location.href=" . $util->baseUrlO . "/admin-index.php';</script>"; | 
// 重 定向 到 后 台 首 页 | 
11 }else{ | 
12 echo "<script>alert( 登 录 失 败 ! </script>": // 给 出 登录 失败 提示 | 
13 } ! 
14 } | 
15 Ssmarty->display('admin-login.phtml’); | 
16 SconnDB->closeConnID(): // 关 闭 数据 库 连接 | 
| 


断 用 户 输入 的 用 户 名 和 密码 是 否 正确 ， 如 果 正 确 ， 则 跳 转 到 后 台 首 页 ;反之 ， 则 提示 登录 
| 失败 。 


5.9 系统 管理 模块 


系统 管理 模块 主要 用 于 网 站 管理 者 对 系统 公用 信息 进行 设置 及 对 管理 员 密码 进行 更 
改 ， 通 过 该 模块 可 以 提高 系统 的 可 维护 性 。 
5 


.9.1 系统 信息 设置 


明日 网 上 书店 的 系统 信息 设置 模块 主要 用 于 设置 商城 DD、 企 业 账号 、 企 业 版 权 、 联 系 
方式 和 程序 文件 的 保存 路 径 等 信息 ， 其 中 用 于 实现 系统 信息 设置 的 表单 如 图 5.33 所 示 。 
.255 | 


图 5.33 ”系统 信息 设置 表单 
当 用 户 在 上 述 表 单 中 设置 完 系 统 信息 并 单 击 “ 设 置 ”按钮 后 ， 表 单 中 的 内 容 将 被 提交 


代码 位 置 ， 配套 资源 mr0svadmin-defaultphp 


01 require once (‘admin-header.php"): // 包 含 admin-header.php 文件 
02 if(isset($ POST[merid]) && $ POST['merid] !=") { // 判 断 是 否 提 交 了 表单 

03 if (! $adminDB->executeSQL("update tb_system set merid=" . $_POST['merid] . ", 

04 meracct=" .$_ POST[meracct] . ". readurl=" .$_ POST[readurl] . ". 


05 bookimgurl=" .$ POST[bookimgurl] . ", ggurl=" .$ POST['ggurl] . ". 
06 bq=".$ POST[bq].".address=".$ POST[address]. "tel=".$ POSTItel] .". 


07 cz=" .$ POST[cz] . ", email=" .$ POST[email] . ". icp=" .$ POST[icp] . ". qq=" . 
08 where mark=1". $connID)) { // 更 改 系 统 信息 

09 echo "<script>alert( 系 统 信息 设置 失败 ! ;</script>"; 

10 }else{ 

a echo "<script>alert(' 系 统 信息 设置 成 功 ! "):</script>"; 
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号 中 | 

13 } 

14 S$system = $adminDB->executeSQL("select id merid, meracct readurl, ! 

15 bookimgurl. ggurl. bq, address. tel. cz, email. icp. qq from tb system where mark=1", | 
$connID): /重新 查询 信息 | 全 站 

16 $smarty->assign('system', $system): | 一 一 

17 $smarty->display('admin-default.phtml'): | 

18 require once (admin-footerphp): // 包 含 admin-footerphp 文件 Note 


上 述 代 码 是 通过 使 用 函数 issetO 判 断 数组 元 素 $ POST[merid] 是 否 被 设置 来 实现 的 ， 
如 果 被 设置 , 则 说 明 已 经 提交 了 表单 ,这 时 用 数据 库 管理 类 的 executeSQL0 方 法 执行 update | 
语句 来 实现 系统 信息 的 更 新 ， 最 后 显示 更 新 结果 。 | 
5.9.2 ”更 改 管理 员 密码 


为 了 便于 网 站 管理 者 对 网 站 进行 管理 ， 提 高 网 站 的 安全 性 ， 在 后 台 系 统管 理 模块 增加 
了 管理 员 密 码 修改 功能 ， 如 图 5.34 所 示 。 


当前 位置; 明 同 上 书店 管理 中 心 更改 和 再 史 三 | ! 


EE LL | 
ES 
六 本: 而 二 二 春生 


(eale 


图 5.34 管理 员 密 码 修改 表单 
用 户 在 上 述 表 单 中 输入 原 密码 和 新 设 定 的 密码 后 ， 单 击 “ 更 改 ” 按 钮 就 可 以 将 表单 中 
的 信息 提交 到 admin-changepwd.php 文件 中 对 密码 进行 更 改 ， 在 该 文件 中 ， 首 先 判断 用 户 
输入 的 原 密码 是 否 正确 ， 如 果 正 确 ， 则 使 用 数据 库 管理 类 的 executeSQL( 方 法 执行 update 
语句 对 管理 员 密 码 进行 更 改 ; 反之 ， 则 给 出 原 密码 错误 的 提示 信息 。 其 中 
admin-changepwd.php 文件 的 相关 代码 如 下 : 
代码 位 置 ， 配 套 资源 mr\05\admin-changepwd.php 


08 truepwd=".$ POST[pwdl] ." where usernc=" .$ SESSION['anc] . "", $connID)) { // 正 
确 则 执行 更 改 操作 
09 echo "<script>alert(' 密 码 更 改 成 功 ! "):</script>"; 
10 } else { 
J echo "<script>alert( 密 码 更 改 失 败 ! "):</script>"; 


01 require once (admin-headerphp)): /包含 admin-headerphp 文 件 | 
02 if(isset($ POST['oldpwd']) && $_ POST['oldpwd'] !=") { 1/ 判断 是否 提交 了 表单 | 
03 if (! $adminDB->executeSQL("select id. usernc from tb_user | 
04 Where usernc=" . $ SESSION['anc] . ”and pwd=" . md5($ POST[oldpwd]) ."", | 
S$connID)){ | 
05 echo "<script>alert(' 原 密码 输入 有 误 ! ');</script>"; /不 正确 则 给 出 提示 | 
06 } else{ | 
07 if ($adminDB->executeSQL("update tb_user set pwd=" . md5($_POST['pwd1"]) . ", | 
| 

| 

| 
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| 下 } 
| 13 } 
| m0 
| 15 $smarty->display('admin-changepwd.phtml’): // 解 析 模 板 
| 16 require once'admin-footerphp'; /包含 admin-footerphp 文件 
“| 
3 5.10 图 书 类 别管 理 模块 
| 
| 
| 为 了 便于 读者 选 购 和 查看 图 书信 息 ， 在 明日 网 上 书店 的 图 书展 示 模 块 中 ， 图 书展 示 功 
| 能 可 以 按照 图 书 分 类 和 出 版 社 分 类 两 种 方式 实现 ， 本 节 将 介绍 图 书 类 别 的 管理 过 程 是 如 何 
| 在 该 网 站 后 台 实现 的 。 
| 5.10.1 图 书 大 类 管理 
| 
| 为 了 提高 图 书 分 类 层次 ， 在 图 书 分 类 展示 模块 中 ， 要 想 对 图 书 类 别 进行 管理 ， 管 理 者 
| 首先 要 选择 图 书 大 类 ， 再 选择 图 书 小 类 来 展示 图 书信 息 列 表 。 图 书 大 类 管理 主要 包括 类 别 
| 的 添加 、 修 改 和 删除 。 
| (1) 在 图 书 大 类 添加 表单 中 输入 图 书 大 类 名 称 ， 然 后 提交 表单 即 可 将 大 类 信息 添加 
| 到 数据 库 中 ， 其 中 用 于 输入 图 书 大 类 的 表单 如 图 5.35 所 示 。 
| 添加 图 书 大 类 信息 
| 大 类 名 称 : [用 序 设计 
| Ea 
| 
| 图 5.35 图 书 大 类 添加 表单 
| 
| 用 户 在 表单 的 文本 框 中 输入 大 类 名 称 ， 然 后 单 击 “ 添 加 ”按钮 即 可 将 表单 提交 到 
| admin-bigtype.php 文件 中 保存 大 类 信息 ， 其 实现 代码 如 下 : 
| 代码 位 置 : 配套 资源 mr\05\admin-bigtype.php 
| 01 Tequire_once (‘admin-header.php"): 
| 02 ”这 (isset($_POST['typename']) && $_POST['typename'] !=") { /判断 是 否 提交 了 表单 
| 03 if (! $adminDB->executeSQL("select id. typename from 
| 04 tb bigtype where typename=" . trim($ POST[Ytypename']) . "", SconnID)) { 
| 05 if(! $adminDB->executeSQL("insert into tb_bigtype(typename, addtime) 
| 06 Values(" . trim($_ POST[Ytypename]) . ". " . date(Y-m-d His) . ")". $connID)) { 
/保存 大 类 信息 
| 07 echo "<scriipt>alert(' 类 别 添加 失败 ! ”):</script>": /给 出 保存 结果 提示 
| 08 }else{ 
| 09 echo "<script>alert( 类 别 添加 成 功 ! ):</script>"; 
| 10 } 
| 11 yelse{ 
| 12 echo "<script>alert( 该 类 别 已 经 添加 ! ):</script>": 
| 13 } 
| 
| 
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CD) 
14 
15 ee 
16 require once (admin-footerphp): 
上 述 代码 首先 使 用 issetO 函 数 判断 用 户 是 否 提交 了 表单 ， 如 果 是 则 使 用 数据 库 管 理 类 | 会 内 
的 executeSQL0O 方 法 保存 图 书 大 类 信息 ， 并 通过 弹出 对 话 框 提示 保存 结果 。 | 一 一 
(2) 对 图 书 大 类 的 修改 和 删除 操作 是 在 如 图 5.36 所 示 的 列表 中 实现 的 ， 该 列表 中 显 医 22 
示 大 类 名 称 和 类 别 添加 时 间 。 


BIRDBRE 


图 5.36 图 书 大 类 信息 列表 
管理 员 单 击 图 书 大 类 列表 中 的 编辑 图 标 即 可 出 现 大 类 编辑 表单 ， 完 成 类 别 更 改 并 提交 | 
表单 后 , 类别 编辑 表单 的 内 容 将 被 提交 到 admin-listbigtype.php 文件 中 , 在 该 文件 中 通过 数 | 
据 库 管理 类 的 executeSQL0 方 法 执行 update 语句 实现 对 大 类 信息 的 更 改 ， 其 实现 代码 如 下 | 
代码 位 置 ， 配 套 资源 mr\05\admin listbigtype.php | 

01 S$isShow = 下" 
02 if((isset($ GET[?]) &&S_ GETIf] =—='edit) | (isset($ POST['?]) &&S POSTI?] =— ‘edit)) { 


03 if(isset($_ POST[f]) && $ POST[f] = 'edit) { // 如 果 为 编辑 操作 
04 让 (! $adminDB->executeSQL("update tb bigtype set typename=" . $ POST 
['typename’] . " 

05 where id-" .$ POST[id] . "".SconnID)) { /执行 update 语句 

05 echo "<script>alert( 类 别 更 改 失 败 ! ");</script>"; /给 出 编辑 结果 | 
07 }else{ ! 
08 echo "<script>alert( 类 别 更 改 成 功 ! ):</scrip>"; | 
09 } | 
TO | 
11 if(isset($ GET['id])) { | 
i $id=$_GET[id]: | 
13 J}else{ | 
14 $id=$_POST[id]: | 
L520 | 


16 Sisshow=TT: | 
17 Sbigtype = $adminDB->executeSQL("select id, typename from tb _bigtype where id=" . $id . | 
™, $connID); | 
18 $smarty->assign('bigtype', Sbigtype): /查询 大 类 名 称 | 
19 } 


。217 。 \ 


Bi 项 目 业 全 分析 


单 击 大 类 名 称 列表 的 删除 图 标 , 首先 会 弹出 一 个 提示 对 话 框 来 提示 用 户 是 否 确认 删除 该 
| 类别， 如 果 是 则 执行 删除 操作 ; 反之 则 不 进行 任何 处 理 ， 这 样 可 以 防止 管理 员 由 于 误 操 作 而 
造成 不 必要 的 损失 。 用 于 实现 图 书 大 类 删除 的 admin-listbigtype.php 文件 的 代码 如 下 所 示 : 
代码 位 置 ， 配 套 资源 mr\05\admin listbigtype.php 
01 if(isset($ GET[?] &&$ GET[f]—'del) { 

Note | 02 让 (! $adminDB->executeSQL("delete from tb bigtype where id=" . $ GET[id] . ™", 

| 

| 

外 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 


03 echo "<script>alert( 类 别 删除 失败 ! ):</script>"， /执行 删除 语句 

04 4 

05 } 
| 上 述 代 码 首 先 使 用 函数 isset0 判 断 $_GET[f] 全 局 数组 是 否 已 经 被 设置 如果 是 则 说 明 
| 管理 员 进 行 了 删除 操作 ， 这 时 将 根据 传递 的 类 别 ID 来 删除 相应 的 类 别 。 


| 5.10.2 图书 小 类 管理 


| 为 了 更 加 精确 地 定位 图 书 ， 方便 读者 查找 ， 明 日 网 上 书店 的 图 书展 示 模块 将 定位 范围 

| 精确 到 小 类 ， 如 程序 类 图 书 又 精确 到 具体 的 开发 语言 。 
(1) 图 书 小 类 添加 表单 

| 图 书 小 类 添加 表单 的 表单 元 素 包 括 小 类 名 称 和 所 属 大 类 下 拉 列 表 ， 其 运行 效果 如 

| 图 5.37 所 示 。 


小 类 名 称 : PP 语 言 


所 属 大 类 : 程序 设计 ~ 
Exe 


图 5.37 图 书 小 类 添加 表单 


| 用 户 首先 在 “小 类 名 称 ” 文 本 框 中 输入 小 类 名 称 ， 然 后 选择 该 小 类 所 属 大 类 ， 单 击 “ 添 
| 加 ”按钮 , 表单 内 容 将 被 提交 到 admin-smalltype.php 文件 中 进行 保存 , 其 实现 代码 如 下 所 示 : 
| 代码 位 置 ， 配 套 资源 mr\05\admin-smalltype.php 


| 01 S$btypes = $adminDB->executeSQL("select id, typename from tb _bigtype order by addtime", 
| $connID): /查询 大 类 
| 02 for($i=0: $i<count($btypes): $i++) { // 将 大 类 信息 保存 到 数组 中 
03 S$arrayBtypeOption[$btypes[$i['id']] = $btypes[Si]['typename']: 
(eh 
05 $smarty->assign(‘arrayBtypeOption'. $arrayBtypeOption): 
06 if (isset($ POST['typename']) && $ POST['typename'] (=") { 
07 if(! $adminDB->executeSQL("select id. typename from 
08 tb_smalltype where typename=" .trim($ POST['typename'"])."", $connID)) { 
09 if(! $adminDB->executeSQL("insert into tb_smalltype(typename. bigtypeid. addtime) 
10 values(" . trim($_ POST['typename]) . ". " .trim($_ POST[bigtypeid]) . ", 
11 "date('Y-m-d H:i:s") .")", $connID)) { /执行 添加 操作 
12 echo "<scriipt>alert( 类 别 添加 失败 ! "):</script>"; 
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! 
13 }else{ | 
14 echo "<script>alert( 类 别 添加 成 功 ! ):</script>": | 
IS } | 
16 }else { | 
7 echo "<script>alert(' 该 类 别 已 经 添加 ! ):</script>": | 加 内 
18 } | 一 一 
1900 | 


上 述 代码 首先 查询 所 有 图 书 大 类 名 称 和 ID 并 保存 到 二 维 数组 中 ， 然 后 通过 Smarty 模 | 
板 的 html_options 标签 将 所 有 大 类 名 称 显示 在 下 拉 列 表 中 ， 再 使 用 函数 isset0 判 断 是 否 提 | 
交 了 表单 ， 如 果 是 则 使 用 数据 库 管理 类 的 executeSQL( 方 法 保存 小 类 信息 。 | 

(2) 图 书 小 类 展示 模块 | 


在 图 书 小 类 展示 模块 中 ， 主 要 显示 图 书 小 类 的 名 称 、 所 属 大 类 和 小 类 添加 时 间 ， 其 运 | 
行 效果 如 图 5.38 所 示 。 | 
| 

EE 名 作 | 

Ee EE ! 

[3 EE | 

EE 司 区 了 本 | 

EU 区 下 | | 

2 EE ! 

Ne EE EE | 

Daohi EE 区 | | 

Em E23 J 世 斑 J| | 

到 Er EE | 

加 E23 EE ! 

EE EE EE | 

rai ED EE | 

EE EE EE ! 

Po EE 区 于 3 | 

| 


图 5.38 图 书 小 类 信息 列表 
当 用 户 单 击 图 书 小 类 信息 列表 页 的 编辑 图 标 后 将 出 现 小 类 编辑 表单 ， 用 户 更 改 小 类 的 
相关 信息 并 提交 表单 后 , 表单 内 容 将 被 提交 到 admin-listsmalltype.php 文件 中 实现 图 书 小 类 
信息 更 改 的 业务 逻辑 ， 其 关键 代码 如 下 : 
代码 位 置 ; 配套 资源 mr\0svadmin listsmalltype.php | 
01 $isShow = 下: | 


02 if((isset($ GET[f) &é&$ GET[T] 一 'edit) || (isset($ POST[fT]) && $ POST[T] 一 'edit)) { | 
03 S$btypes = $adminDB->executeSQL("select id, typename from tb bigtype order by addtime"、 | 


$connID): /获得 大 类 信息 

04 for ($i= 0: $i < count($btypes): $i++) { // 将 大 类 信息 保存 到 数组 中 | 

05 $arrayBtypeOption[$btypes[$il[id]] = Sbtypes[$i][typename']; | 

06 } | 

07 $smarty->assign(‘arrayBtypeOption'. $arrayBtypeOption): | 

08 if (isset($_POST['f]) && $ POST[f] = 'edit) { // 进 行 编辑 操作 

09 if (! $adminDB->executeSQL("update tb_smalltype 

10 set typename=" . $ POST['typename'] . " bigtypeid=" .$ POST[bigtypeid] . " | 

11 whereid=".$ POST[id]."".SconnID)) { | 

12 echo "<script>alert( 类 别 更 改 失败 ! ):<Jscript>"; | 

13 }else { | 

14 echo "<script>alert( 类 别 更 改 成 功 ! ):</script>": | 
| 
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| 15 } 

| Te 

| 17 if(isset($ GET[id])){ 
8 $id=$ GET[id]: 
ii }else{ 
20 $id=$ POST[id]: 


23 $smalltype = $adminDB->executeSQL("select id typename. bigtypeid from tb_smalltype 
”where id=" . $id . "". SconnID); /查询 小 类 信息 
24 $smarty->assign('smalltype'. $smalltype): 
25 } 
| 上 述 代码 首先 判断 $_GET['f"'] 数 组 元 素 是 否 已 经 设置 ， 如 果 是 则 说 明 管 理 者 已 经 单 击 
编辑 图 标 ， 这 时 所 有 的 大 类 名 称 作 为 查询 结果 返回 ， 并 使 当前 编辑 小 类 所 属 的 大 类 名 称 处 
于 选中 状态 ， 然 后 判断 $_POST['f] 数 组 元 素 的 值 是 否 被 设置 ， 如 果 是 则 说 明 已 经 更 改 小 类 
| 信息 表单 ， 此 时 通过 数据 库 管理 类 的 executeSQL0 方 法 更 改 小 类 信息 。 
| 如 果 管理 员 单 击 小 类 信息 列表 的 删除 图 标 ， 则 页 面 会 弹出 一 个 提示 对 话 框 来 提示 用 户 
| 是 否 确 认 删 除 ， 如 果 是 则 通过 数据 库 管 理 类 的 executeSQL0O 方 法 执行 delete 语句 删除 指定 
| 的 小 类 信息 ， 该 过 程 是 在 admin-listsmalltype.php 文件 中 实现 的 ， 其 实现 代码 如 下 所 示 : 
代码 位 置 ， 配 套 资源 mr\05\admin listsmalltype.php 
01 if(isset($ GEI[f']) && $ GET[?] = 'del) { 


| 02 if (! $adminDB->executeSQL("delete from tb_smalltype where id=" . $_ GET[id] ."™, 

| $connID)) { 
03 echo "<script>alert( 类 别 删除 失败 ! ):</script>": /执行 删除 

04 } 

5 


5.10.3 出 版 社 分 类 管理 


为 了 方便 引导 读者 选 购 自己 信赖 的 出 版 社 所 发 行 的 图 书 ， 明 日 网 上 书店 提供 了 除 可 以 
| 按 内 容 查找 图 书 ， 还 可 以 按 所 属 出 版 社 实现 分 类 查找 的 功能 。 所 以 ， 为 了 有 效 地 管理 出 版 
| 社 的 信息 ， 在 后 台 管 理 模块 中 添加 出 版 社 分 类 管理 是 十 分 必要 的 。 
| (1) 出 版 社 类 别 输入 表单 
| 与 图 书 内 容 分 类 略 有 区 别 ， 为 了 使 出 版 社 分 类 更 加 形象 、 易 于 识别 ， 在 出 版 社 分 类 模 
| 块 中 ， 管 理 者 可 以 增加 出 版 社 logo 图 片 信息 ， 其 表单 运行 效果 如 图 5.39 所 示 。 


| 添加 出 版 社 类 别 信息 


出 版 社 名 称 : 和民 邮电 出 版 社 


出 版 社 loge 图 片 : C: \Users\Adninistrator\Desktop\| 浏览 .. 


EE 


图 5.39 ”出 版 社 类 别 输入 表单 


2 
| 
| 
| 
| 
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| 
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| 
| 
| 
| 
| 
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| 
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网 站 管理 者 在 添加 完 出 版 社 名 称 并 选择 了 出 版 社 logo 图 片 后 ， 单 击 “ 添 加 ”按钮 即 可 | 
将 出 版 社 类 别 信息 提交 到 admin-pub.php 文件 中 进行 处 理 ， 其 实现 代码 如 下 : 
代码 位 置 : 配套 资源 \mr\05\admin-pub.php 


01 if(isset($ POST[pubname]) && $ POST[pubname] !=") { // 如 果 提 交 了 表单 | 食 生 | 

02 if(! $adminDB->executeSQL("select id, pubname | 

03 from tb_pub where pubname=" . trim($ POST[pubname]) . "", SconnID)) { /判断 MNote 
该 出 版 社 是 否 已 经 添加 | 

04 if (isset($_FILES["pubimg"]["name"]) && $ FILES["pubimg"]["name"] !="") { // 上 传 | 
出 版 社 logo | 

05 $dir = "./upfiles/bookimg"; | 

06 if(!is dir($dir)) { | 

07 mkdir($din): | 

08 } | 

09 S$upfilename =$_FILES["pubimg"]["name"]: | 

10 $filename = date("YmdHis") . mt_rand(1000. 9999) . | 

11 substr($upfilename, strpos($upfilename, "."). | 

12 strlen($upfilename) - strpos(Supfilename. "六 /设置 出 版 社保 存 文件 名 | 

13 S$address = $dir . "/" . $filename: | 

14 move uploaded fle($_FILES["pubimg"]["amp name"]. Saddress) /执行 上 传 操作 | 

15 } else { | 

16 $filename = ""; | 

17 E 

18 if (! $adminDB->executeSQL("insert into tb_pub(pubname, pubimg, addtime) 


| 
19 values(" .trim($ POST[pubname']) . ", | 
20 mm.g$filename . "," .date(CY-m-dH:is) .")".$connID)){ // 保 存 出 版 社 类 别 信息 | 


21 echo "<script>alert(' 出 版 社 类 别 添加 失败 ! ”):</script>"; 

22 } else{ 

23 echo "<script>alert(' 出 版 社 类 别 添加 成 功 ! :</script>"; 

24 } 

25 }else{ 

26 echo "<script>alert( 该 出 版 社 类 别 已 经 添加 ! ');</script>"; 

27 | 
2 | 


上 述 代码 使 用 move_uploaded_file0 函 数 上 传 出 版 社 logo， 当 logo 文件 被 成 功 上 传 到 | 
服务 器 特定 目录 后 ， 该 处 理 页 会 应 用 数据 库 管理 类 的 executeSQL( 方 法 执行 insert 语句 ， 
将 出 版 社 类 别 信息 添加 到 数据 库 中 。 | 

(2) 出 版 社 类 别 信息 列表 | 

出 版 社 类 别 信息 列表 页 显示 出 版 社 的 logo、 出 版 社 名 称 和 类 别 添 加 时 间 ， 其 运行 效果 | 
如 图 5.40 所 示 。 


ET 
入 人 民 邮 电 出 纤 社 

站 ET ET 

@ EC ET 严正 


图 5.40 出 版 社 类 别 信息 列表 
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单 击 出 版 社 类 别 列 表 中 的 编辑 图 标 ， 将 显示 更 改 出 版 社 类 别 的 表单 ， 当 管理 者 编辑 完 


| 出 版 社 信息 并 提交 表单 后 ， 表 单 内 容 将 会 被 提交 到 admin-listpub php 文件 中 进行 处 理 ， 


| 实现 代码 如 下 : 
代码 位 置 : 配套 资 源 \mr\05\admin listpub.php 
01 $isShow = 下 ': 
02 if((isset($ GET[f) &&S GET[T] 一 'edit) | (isset($ POST[fD &&S POST[ 人 一 edit)) { 
03 if (isset($ POST[T]) && $ POST[f] — "edit) { 
04 if (isset($_FILES["pubimg"]["name"]) && $_FILES["pubimg"]["name"] !="") { // 判 断 
是 否 重新 上 传 logo 
05 $dir = "./upfiles/bookime"; 
06 if(!is dir($dir) { 
07 mkdir($dir); 
08 
09 Supfilename = $_FILES["pubimg"]["name"]; 
10 $filename = date("YmdHis") . mt _rand(1000, 9999) . 
11 substr($upfilename, strpos($upfilename, "."), 
12 strlen($upfilename) - strpos($upfilename, ".")); 
13 $address = $dir . "/" . $filename; 
14 @move_uploaded file($_FILES["pubimg"]["tmp_name"], $address); // 执 行 上 传 
15 } else{ 
16 $ptmp = $adminDB->executeSQL("select pubimeg from tb pub where id=" . trim ($ POST 
Tid]) ."™, $connID): 
17 Sfilename = $ptmp[0][pubimg']: 
18 了 
19 这 (! $adminDB->executeSQL("update tb pub 
20 set pubname=" .$ POST[pubname'] . ", pubimg='" . $filename . ” 
21 whereid=".$ POST['id] ."".SconnID)) { /更改 出 版 社 类 别 信息 
22 echo "<script>alert( 出 版 社 类 别 更 改 失 败 ! ):</script>": 
23 } else { 
24 echo "<script>alert( 出 版 社 类 别 更 改 成 功 ! ");</script>"; 
25 } 
D000 
27 if(isset($ GET[id])) { 
28 $id=$_ GET['id]: 
29 }else{ 
30 $id=$ POST[id]; 
31 
32 S$isShow = "T'; 
33 $pub = $adminDB->executeSQL("select id, pubname, pubimg from tb_pub where id=" . $id . 
™™, $connID): 
34 $smarty->assiegn(‘pub'. $pub):; 
S50 


上 述 代码 首先 判断 管理 者 是 否 在 编辑 出 版 社 信息 的 同时 又 重新 上 传 出 版 社 logo， 如 果 


是 则 了 


外 新 上 传 ， 反 之 则 不 进行 任何 操作 ， 然 后 使 用 数据 库 管理 类 的 executeSQL0O 方 法 执行 


update 语句 来 实现 更 改 出 版 社 类 别 信息 的 操作 。 
如 果 单 击 出 版 社 类 别 列表 中 的 删除 图 标 ， 并 确认 删除 后 ， 出 版 社 类 别 信息 将 会 通过 如 


vs 
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下 代码 删除 。 


if (isset($_GET['f)) &&$ GET[?]—='del) { 

if(! $adminDB->executeSQL("delete from tb_pub where id=" .$_ GET[id] . "". $connID)) { 
echo "<script>alert(' 出 版 社 类 别 删除 失败 ! ”):</script>"; | 会 内 

} | 会 


| 


上 述 代 码 使 用 数据 库 管理 类 的 executeSQL( 方 法 并 根据 GET 方法 传递 的 出 版 社 的 了 D 
值 实现 指定 出 版 社 信息 的 删除 操作 。 


5.11 图 书 管理 模块 | 


图 书 管理 模块 主要 用 于 实现 网 站 管理 者 对 图 书信 息 和 图 书 试 读 信息 执行 管理 操作 ， 本 
节 将 对 明日 网 上 书店 如 何 实现 图 书信 息 管理 进行 系统 分 析 。 


5.11.1 图 书信 息 管 理 


明日 网 上 书店 主要 通过 图 书信 息 展示 来 扩大 销售 范围 ， 所 以 图 书信 息 管理 模块 与 其 他 | 
管理 模块 相 比 ， 更 能 突出 其 关键 地 位 ， 该 项 目的 图 书信 息 管理 模块 主要 包括 图 书信 息 的 添 | 
加 、 更 改 、 删 除 和 查询 等 功能 。 

(1) 图 书信 息 表单 | 

图 书信 息 包括 图 书 的 名 称 、 类 别 、 页 数 、 字 数 、 作 者 、ISBN 号 和 价格 等 ， 明 日 网 上 | 
书店 的 图 书信 息 输入 表单 如 图 5.41 所 示 。 


TEN | 
四 区 下 开发 实 上 宝 册 | 
MR FP -Wal : ER | 
rh (页 大雪 [0 要 (这 ) | 
IS: [T7020960-5 上 多: [2010 芋 1 月 雪 1 原 | 
作者。 前 利 技 i 1 年 工 a | 
原价 [ 古 , 有 0 《元 ) 会 员 价 : [0 ] (元 ) | 
[Ed 组 S 图 TB。 二 志 《 字 个 号 十 扫 基 ， 如 | 1229 | 
加 和 居 画 : EDGEUGNIRLSEESEOTDeSKEODASEEUERSDIESVEIESE De ng [EP | | 

[3 四 | 
| | | 
F E 
有 内容 简介 : >| | 
新: 团 关怀: 国 1: 目 。。 症 ES: 国 。 用: 司 
加 


1 
5.41 添加 图 书信 息 表单 | 
1 


网 站 管理 员 首 先 在 图 5.41 所 示 的 表单 中 输入 图 书信 息 ， 然 后 单 击 “ 添 加 ”按钮 ， 则 图 
书信 息 将 被 提交 到 admin-book.php 文件 中 进行 保存 ， 其 实现 代码 如 下 : 


。223 。 k 


| POST[bc]) .". 
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9 
代码 位 置 ， 配 套 资源 \mr\05\admin-book.php 
01 让 (isset($_ POST[boolmname]) && $ POST[boolkmname'] :="&&S$S POST['G ee 一下) { 
02 if(! $adminDB->executeSQL("select id bookname 
03 from tb_bookinfo 
04 where bookname=" . trim($ POST[bookname']) . "". $connID)) { // 判 断 图 书信 息 是 否 已 经 
被 添加 
05 if (isset($ FILES["bookimg"]["name"]) && $ FILES["bookimg"]["name"] (="") { 
06 dir = "./upfiles/bookimg": 
07 if (lis dir($dir) { 
08 mkdir($dir); 
09 b 
10 S$upfilename = $_FILES["bookimg"]["name"]: 
1 Sfilename = date("YmdHis") . mt_rand(1000. 9999) . 
12 substr($upfilename, strpos($upfilename. "."). 
13 strlen($upfilename) - strpos($upfilename. ".")): // 设 置 图 书 封 面 名 称 
14 ;$address = $dir . "/" . $filename; 
15 @move_uploaded file($ FILES["bookimg"]["tmp_name"], $address); /上 传 图 书 封面 
16 }else { 
17 $filename = ""; 
18 } 
19 $pubtime =$_POST[pyear] .'- .$ POST[pmonth ] . '-00'; 
20 让 (! $adminDB->executeSQL("insert into tb_bookinfo(bookname, smalltypeid, pubid, 
21 page, zs, isbn, bc,writer, pubtime, oldprice, newprice, bookcc, bookids, bookimg, directory, 
2 about, isnew, issepprice, ishotsell, isterm ,ismrbookti ,ishave, addtime, browsertime) 
23 values(" . trim($ POST[bookname]) . ", " . trim($ POST['smalltypeid]) . ". ™" 


IE POST[pubid]) . ". 


24 


25 


" . trim($ POST[writer]) . " " . $pubtime . ". " . trim($ POST[oldprice]) . ". " . 


| iG _POST[mewprice]) .", 


26 


- trnm 
eS .tim($ 1 POST[page]) .", " . trim($ POST[zs]) . "," .trim($ POST['isbn]) .™, " . trim 
trm 
trim 


ey .trim($ ] POST[bookcc]) . ™, " . trim($ POST[bookids]) . ", " . $filename . ",™". tri 


| | 区 _POST['directory]) .", 


27 
28 


这 timGs ] POST[about]) . "," .trim($_ POST[isnew]) . "," .trim($_ POST['issepprice]) . "， 
™ . trim($ POST[ishotsell]) . ”，” . trim($ POSTistemm) ES 和 bm 


| ($. le ey 


tm ] POST[ishave]) .".". date('Y-m-d His) . ".'0)", SconnID)) { // 保 存 图 书信 息 
echo "<script>alert(' 图 书 添加 失败 ! ):</script>": 
}else{ 
echo "<script>alert(' 图 书 添加 成 功 ! ):</script>": 


} 
}else{ 
echo "<script>alert( 该 图 书 已 经 添加 ! "):</script>"; 
} 
} 
$isEdit= 下 ': 


if(isset($ GET[f]) && $ GET[ 们 一 edit | isset($_ POST['change']) && $ POST['change] — T) { 
if (isset($_ POST['change']) && $ POST['change'’] — 'T') { 
if (isset($_ FILES["bookimg"]["name"]) && $ FILES["bookimg"]["name"] (= "") { 
$dir ="./upfiles/bookimg": 
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43 让 (is dir($dir) { 

44 mkdir($dir): 

45 } 

46 Supfilename = $_FILES["bookime"]["name"]: 

47 Sfilename = date("YmdHis") . mt rand(1000，9999) . substr($upfilename. 


strpos($upfilename., "."). 


i Ec 
49 ; $address = $dir . "/" . $filename: Note 


50 @move_uploaded file($ FILES["bookimg"]["tmp_ name"], Saddress): 
S1 }else{ 

人 Stmpbook = $adminDB->executeSQL("select bookimg from tb bookinfo 
54 $filename = $tmpbook[0][bookimg']: 

55 } 


56 $pubtime = $ POST['pyear] .~'. $ POST[pmonth'] . -00': 

…// 省 略 代码 用 户 设置 用 户 提交 内 容 ， 请 参见 本 书 配 套 资源 中 源码 
57 if(! $adminDB->executeSQL("update 也 bookinfo set bookname=" . trim($ POST[bookmname]) .", 
58 smalltypeid=" . trim($ POST['smalltypeid]) . ", pubid=" . trim($_ POST[pubid]) .", 
59 page=" .trim($ POST[page]) . ", zs=" .trim($ POST[zs]) . "isbn=" .tuim($ POST[isbn]) . "， ! 
60 bc=". trim($ POST[bc]) . "writer=" .trim($_ POST[writer]) . ", pubtime=". Spubtime .", | 
61 oldprice=" .trim($ POST['oldprice]) . ", newprice=" .trim($ POST[mewprice]) .™, | 
62 bookcc=" .trim($ POST[bookcc]) . ", bookids=" .trim($ POST[bookids]) . "、 | 
63 bookime=". $filename .", directory=" .trim($ POST[directory]) . "、 | 
64 about=" .trim($ POST['about]) . ", isnew="" . $isnew . ", issepprice="" . $issepprice . "， | 
65 ishotsell=". $ishotsell . ", isterm="". $isterm . " ,ismrbooktj=" . $ismrbooktj . ™ ,» | 
66 ishave=" . $ishave . "” where id=" .$ POST['id] ."", $connID)) { /更 改 图 书信 息 | 


| 
53 whereid=".$ POST['id].™", $connID); | 
| 


67 echo "<script>alert( 图 书信 息 更 改 失败 ! ):</script>": | 
68 }else { ! 
69 echo "<script>alert( 图 书信 息 更 改 成 功 ! ');</script>"; | 
70 } | 
71 


} 
72 if(isset($_ POST['id])){ 
73 $id=$ POST[Tid]: 


74 }else{ ! 
75 $id=$_GET['id]; | 
76 } 


77 $isEdit='T'; | 

78 $book = $adminDB->executeSQL("select id, bookname. smalltypeid, pubid, page. zs. isbn, be. 
writer, pubtime、 ! 

79 oldprice, newprice, bookcc. bookids, bookimg, directory, about, isnew, issepprice, ishotsell, 

80 term .ismrbooktj .ishave, addtime, browsertime from tb_bookinfo where id=" . $id . ™ ", 
$connID): // 查 询 图 书 

81 $smarty->assign(‘book', $book): 

82 $smarty->assien('pyear'. substr($book[0][pubtime']. 0. 4)): 

83 $smarty->assign(‘pmonth'. substr($book[0][pubtime']. 5. 2)): 

84 } 


上 述 代码 同时 实现 图 书信 息 添 加 和 更 新 两 种 操作 。 首 先 判断 8$_ POST['change] 数 组 元 素 
的 值 ， 如 果 该 值 为 F， 则 说 明 网 站 管理 者 选择 的 是 图 书信 息 添加 操作 ， 通 过 数据 库 管理 类 


ss 


人 Be 项 目 业 例 分 析 
WW REER 


| 的 executeSQL0O 方 法 执行 insert 语句 将 图 书信 息 保 存 到 数据 库 中 ， 同 时 使 用 move 


uploaded file0 函 数 将 图 书 封面 上 传 到 服务 器 中 ; 如 果 $_POST['change] 的 值 为 T, 则 说 明 网 
站 管理 者 选择 的 是 对 指定 图 书信 息 进 行 更 改 操作 。 对 图 书信 息 更 改 时 ， 处 理 页 需要 判断 图 


| 书 封面 是 否 被 重新 选择 ， 如 果 是 则 对 图 书 封面 重新 上 传 ， 最 后 执行 update 语句 对 图 书信 息 


进行 更 新 。 
(2) 图 书信 息 列表 
图 书信 息 列表 主要 对 图 书 名 称 、 出 版 社 、 作 者 和 价格 等 信息 进行 分 页 显示 ， 其 运行 效 


果 如 图 5.42 所 示 。 
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5.42 图书 信息 列表 


通过 图 书信 息 列 表 页 可 以 实现 对 图 书信 息 的 更 改 和 删除 操作 ， 前 面 已 经 对 图 书信 息 更 
改 的 实现 方法 做 过 介绍 ， 这 里 不 再 袭 述 。 当 管理 者 单 击 图 书信 息 列表 的 删除 图 标 后 ， 页 面 
会 弹出 提示 对 话 框 询问 管理 者 是 否 确认 删除 操作 ， 如 果 是 则 通过 下 述 代 码 执行 对 图 书信 息 
的 删除 操作 。 

这 (isset($ GET[fY]) &&S GET[T] 一 del){ 
if(! $adminDB->executeSQL("delete from tb_bookinfo where id=" .$_GET[id] ."", $connID)) { 
echo "<script>alert(' 图 书信 息 删 除 失败 ! ):</script>": ”// 执 行 删除 操作 
} 
} 
(3) 图 书信 息 查询 

与 其 他 管理 模块 相 比 ， 图 书信 息 管理 模块 显示 的 数据 较 多 ， 为 了 方便 管理 者 对 图 书信 
息 进 行 管理 ， 在 图 书信 息 管理 模块 中 ， 管 理 者 可 以 通过 图 书 查询 功能 ， 查 询 出 与 所 提交 关 
键 字 相关 的 图 书信 息 ， 其 运行 效果 如 图 5.43 所 示 。 
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图 5.43 ”图书 信息 查询 
首先 在 “查询 关键 字 ” 文 本 框 中 输入 要 查询 的 关键 字 ， 然 后 单 击 “ 查 询 ” 按 钮 ， 这 时 
查询 表单 的 内 容 将 被 提交 到 admin-searchbook.php 文件 实现 业务 逻辑 ， 其 代码 如 下 所 示 : 
代码 位 置 ; 配套 资源 mr\0svadmin-searchbook.php 
01 SisFind = F': 


02 if (isset($ POST[bookname]) && $ POST[boolkmname'] !=" || isset($ GET[bookname]) && 
03  $ GET[bookname] !=") { // 判 断 是 否 提交 了 表单 
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04 1f(isset($ POST['bookname'])) { // 获 取 要 查询 的 图 书 名 称 


05 S$bookname = $ POST[bookname']: 
06 }else{ 

07 $bookname =$ GET[bookname']: 
08 } 


09 $books = $adminDB->executeSQL("select tb bookinfo.id, tb bookinfo.oldprice, tb bookinfo. 


10 tb bookinfo bookname, tb_bookinfo writer tb_ pub.pubname from tb_bookinfo, tb pub 
如 where tb_bookinfo.pubid = tb_pub.id and bookname 
12 like'%".$bookname."%’ orderby tb bookinfo.addtime desc", $connID);  // 执 行 模糊 查询 
13 $smarty->assign(books', Sbooks): 
14 $isFind='"T'; 
15 $smarty->assign(‘bookname'’, $bookname); 
} 


上 述 代码 首先 使 用 函数 isset0 判 断 $_POST['bookname'"] 数 组 元 素 是 否 已 经 被 设置 ,如果 
是 则 使 用 数据 库 管理 类 的 executeSQL0O 方 法 执行 查询 操作 。 


5.11.2 ”图 书 试 读 管理 


为 了 让 读者 选择 一 本 真正 适合 自己 的 图 书 ， 吸 引 更 多 读者 购买 ， 在 开发 明日 网 上 书店 
的 过 程 中 ， 考 虑 到 让 读者 在 选 购 图 书 之 前 ， 可 以 对 图 书 的 大 体内 容 有 初步 的 认识 ， 为 了 满 
足 这 一 系统 要 求 ， 明 日 书店 系统 在 前 台 增 加 了 图 书 试 读 模 块 ， 这 样 读者 在 购买 图 书 前 就 可 
以 对 想 要 购买 的 图 书 有 一 定 了 解 ， 让 读者 感到 非常 人 性 化 。 为 了 保证 新 书 的 实时 性 以 及 管 
理 的 便捷 、 高 效 性 ， 在 后 台 增 加 一 个 图 书 管理 模块 就 显得 非常 有 必要 。 

(1) 添加 图 书 试 读 信息 表单 

添加 试 读 信息 的 表单 中 包含 图 书 “ 类 别 ” 下 拉 列 表 框 “图 书 名 称 ” 下 拉 列 表 框 和 “ 试 
读 文 件 名 ”文本 框 ， 其 运行 效果 如 图 5.44 所 示 。 
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图 5.44 添加 图 书 试 读 信息 表单 
用 户 输入 试 读 信息 后 ， 单 击 “ 添 加 ”按钮 即 可 将 试 读 信息 提交 到 admin-read.php 文件 
中 进行 处 理 ， 并 将 试 读 信息 保存 到 相关 数据 库 中 ， 其 实现 代码 如 下 : 
代码 位 置 ， 配套 资源 mm0svadmin_ read.php 
01 $btypes = $adminDB->executeSQL("select id typename from tb_bigtype order by addtime". 


$connID): /查询 图 书 大 类 
02 for ($i = 0: $i < count($btypes): Si ++) { // 将 大 类 保存 到 数组 中 
03 $arrayBtypeOption[Sbtypes[Sil[id]] = Sbtypes[$Sil[typename']: 
te 


05 $smarty->assign(arrayBtypeOption'. $arrayBtypeOption): 
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让 (isset($_POST[filename]) &&S$ POST[Yfilename] (= ") { // 济 断 是 否 提交 了 表单 


if(! $adminDB->executeSQL("select id. filename from tb read 
where bookinfoid=" . $ POST[bookid] ."". $connID)) { ”// 判 断 该 书 的 试 读 信息 是 否 已 经 添加 
if (! $adminDB->executeSQL("insert into tb read(bookinfoid, filename. addtime) 


‘values(". $_ POST[bookid] . ", " . $ POSTT'filename’] . ". " . date('Y-m-d Hii:s) . ")", $connID)) { 


echo "<scriipt>alert(' 试 读 添加 失败 ! :</script>"; 
jelse 
echo "<script>alert(' 试 读 添加 成 功 ! "):</script>"; 


} 
}else{ 

echo "<script>alert(' 已 经 为 该 图 书 添加 试 读 ! ;</script>"; 
b 
BE 


当 提 交 试 读 信息 到 上 述 页 面 后 ， 用 户 提 交 的 数据 将 通过 数据 库 管 理 类 的 executeSQLO 
方法 被 保存 到 相应 数据 库 中 。 
(2) 图 书 试 读 信息 列表 
试 读 信 息 列表 页 主要 以 分 页 的 形式 显示 出 试 读 图 书 的 名 称 、 文 件 名 和 添加 时 间 等 信 
息 ， 其 运行 效果 如 图 5.45 所 示 。 
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图 5.45 ”图书 试 读 信息 列 表 


单 击 试 读 信 息 列表 的 编辑 图 标 后 ， 页 面 将 会 自动 加 载 试 读 信息 更 改 表单 ， 在 该 表单 中 
修改 试 读 图 书 的 内 容 ， 单 击 “ 提 交 ” 按 钮 ， 将 编辑 后 的 数据 提交 到 admin-listread.php 页 面 
中 进行 修改 ， 其 实现 代码 如 下 所 示 : 

代码 位 置 ， 配 套 资源 mr\05\admin listread.php 


if((isset($ GET[f)]) &é& $ GET[f]=—'edit) | (isset($ POST[f)) && $ POST[?] = 'edit){ 
if (isset($_ POST[f)]) && $ POST[f] =—= 'edit) { 
if(! $adminDB->executeSQL("update tb_read 
set bookinfoid=" .$_ POST[bookid] . ", filename=" . $_POST['filename’] ." 
where id=" .$ POST[id] . "™", $connID)) { // 执 行 更 改 操作 
echo "<script>alert( 试 读 更 改 失 败 ! ):</script>": 
}else{ 
echo "<script>alert( 试 读 更 改 成 功 ! ):</script>": 
} 
} 
if (isset($ GET[id])) { 
$id=$_ GET[id]: 
}else{ 
$id=$_ POST['id]: 
} 
S$isShow = "T': 
Sread = $adminDB->executeSQL("select tb readid, tb read.filename, tb bookinfo. 


“238s 


第 5 章 明日 网 上 书 计 (PHprkymartrHaDODPHHSQLC 实现 ) 


& ! 
bookname. tb read.addtime | 
18 fromtb read tb bookinfo | 
19 ”where tb readbookinfoid = tb bookinfo id and tb read.id=" . $id . "". $connID); /查询 试 | 
读 信息 | 
20 S$smarty->assign(read' Sread): | 4 
wl | 鲜 
单 击 试 读 信息 列表 的 删除 图 标 ， 会 弹出 是 否 确认 删除 的 对 话 框 ， 如 果 选 择 确认 删除 则 甘 2&9 
会 通过 如 下 代码 实现 试 读 信息 的 删除 。 
if (isset($_GET['?]) &&$ GET[T] 一 'del) { | 
证 (! $adminDB->executeSQL("delete from tb read where id-" .$_GET[id] . "". $connID)) { 
echo "<script>alert(' 试 读 删除 失败 ! ):</scripP": /执行 删除 试 读 操作 | 
} 
} 


5.12 用户 信 息 管 理 模块 

明日 网 上 书店 的 用 户 信息 管理 模块 主要 用 于 网 站 管理 者 对 用 户 的 个 人 注册 信息 以 及 | 

用 户 反馈 信息 进行 管理 。 | 
5.12.1 用 户 信息 管理 


通过 用 户 信息 管理 模块 可 以 对 用 户 的 注册 信息 进行 查看 或 删除 操作 ， 其 运行 效果 如 
图 5.46 所 示 。 
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图 5.46 用 户 信息 列表 | 
创建 admin-listuserphp 文件 ， 当 用 户 在 该 文件 中 单 击 “ 查 看 用 户 信息 ”按钮 时 ， 将 显 | 
示 出 该 用 户 的 详细 信息 ， 其 实现 代码 如 下 所 示 : 
代码 位 置 ， 配 套 资源 \mr\05\admin-listuser.php 
01 。 if(!isset($_GET[page) ||$_GET[page] 一 ") { /获得 页 码 


02 Spage = "1'; 

03 J}else{ 

04 Spage =$_GET['page']: | 
05 | 
06 if(isset($_GET[f]) && S$ GET[f]='del) { // 判 断 是 否 进行 删除 操作 | 
07 if(! $adminDB->executeSQL("delete fom tb user where id=" .$_ GET[id] .ww $connID) {| 
08 echo "<script>alert( 用 户 信息 删除 失败 ! ”);</script>"; | 
09 } | 
10 } | 
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$sql = "select id, usernc. truename. email. sex. tel. qq. address. logintimes. regtime, 


| | ip. yb, usertype 


from tb_user order by Usertype desc, regtime desc": // 构 建 查询 语句 
i $users = $pageDB->pageData($sql. $connID. 20, $page): 。“ // 执 行 分 页 查询 
14 $smarty->assign('users'. $users): 
[by S$isShow = F'; 
16 if(isset($ GET[T]) &&$ GET[f]—='edit) { // 查 询 指 定 用户 的 信息 
TI7 Suser = $adminDB->executeSQL("select id, usernc. truename, email, sex, tel, qq, address, 
| logintimes, regtime, 
| 18 lastlogintime, ip, yb, usertype 
19 from tb user where id=" .$ GET['id] . "". $connID): 
20 $smarty->assign('‘user’, $user): 
21 S$isShow='T'; 
22 } 


上 述 代码 首先 通过 $_GET 全 局 数组 接收 传递 的 查询 字符 串 page 的 值 ， 然 后 使 用 数据 


库 分 页 类 的 pageData() 方 法 实现 分 页 查询 。 


5.12.2 ”用 户 反馈 信息 管理 


为 了 征集 读者 的 意见 ， 从 而 更 好 地 经 营 和 管理 网 站 ， 在 制作 明日 网 上 书店 时 ， 还 增加 
了 用 户 意见 反馈 模块 ， 用 户 意见 反馈 列表 如 图 5.47 所 示 。 
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图 5.47 用 户 反馈 信息 列表 


单 击 用 户 反馈 信息 列表 中 的 编辑 图 标 ， 将 显示 出 用 户 的 详细 反馈 内 容 ， 其 主要 过 程 是 
在 admin-listuserfeedback.php 文件 中 完成 的 ， 其 代码 如 下 所 示 : 
代码 位 置 ， 配 套 资源 mr\05\admin listuserfeedback.php 


站 (! isset($_GET['page') |$_GET['page'] 一 ") { /获得 页 码 
Spage= "1'; 

}else { 
Spage=$ GET[page]: 


if(isset($_GET[f]) && $_GET[f] 一 'del) { ”// 判 断 是 否 进行 删除 操作 
if(! $adminDB->executeSQL("delete from tb feedback where id=" .$ GET[id] .™", $connID)) { 
echo "<script>alert( 用 户 反馈 信息 删除 失败 ! :</script>"; 
) 
} 
$sql = "select id usernc. title. addtime from tb_feedback order by addtime desc": /构建 查询 语句 
Sfeedbacks = $pageDB->pageData($sql. $connID, 20. $page):” // 执 行 分 页 查询 
$smarty->assign('feedbacks'. $feedbacks): 
S$isShow = 下 ': 
让 (isset($_GET[f]) &&S$_GET[f] 一 'edit) { /查询 指定 用 户 反馈 信息 
$userfeed = $adminDB->executeSQL("select id usernc. title, content, addtime 
from tb_ feedback where id=" .$_ GET['id'] ."", $connID): 
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$7 
18 S$isShow = "T': 
19 $smarty->assien('‘userfeed'. $userfeed): 


200) 
上 述 代 码 首先 接收 传递 的 查询 字符 串 page 的 值 , 然后 使 用 数据 库 分 页 类 的 pageDataO | 会 内 
方法 实现 用 户 反馈 信息 的 分 页 。 | 一 一 


5.13 ”订单 信息 管理 模块 
通过 明日 网 上 书店 的 订单 管理 模块 可 以 对 读者 的 订购 信息 进行 管理 ， 下 面 介 绍 该 项 目 
订单 管理 模块 的 实现 方法 。 
5.13.1 ”订单 信息 列表 管理 


明日 网 上 书店 的 订单 列表 主要 显示 订单 号 、 订 购 人 、 联 系 电话 、 订 购 图 书 所 要 支付 的 
各 项 费用 以 及 目前 的 支付 状态 等 信息 ， 其 运行 效果 如 图 5.48 所 示 。 
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图 5.48 用户 订 单列 表 
用 户 订单 管理 的 主要 操作 包括 订单 支付 状态 的 更 改 、 订 单 信息 的 查看 和 删除 等 。 下 述 
代码 根据 传递 的 查询 字符 串 page 的 值 并 通过 数据 库 分 页 类 的 pageData0 方 法 实现 订单 信息 
的 分 页 显示 ,通过 数据 库 管 理 类 的 executeSQL0O 方 法 执行 update 语句 实现 订单 状态 的 更 改 。 
相关 过 程 在 admin-listorderphp 文件 中 完成 ， 其 代码 如 下 : 
代码 位 置 ， 配 套 资源 mr\05\admin -listorder.php 


01 if(!isset($ GET['page') ||$ GET['page] =—=") { // 获 得 当前 页 码 | 
02 Spage = "1'; | 
03 J}else{ | 
04 S$page=$_GET[page]: 
05 | 
06 if(isset($_GET[f]) &&$ GET[f]—='del) { // 对 订单 进行 删除 | 
07 if (! $adminDB->executeSQL("delete from tb_order where id=" . $ GET[id] . "| 
$connID)) { | 
08 echo "<script>alert( 订 单 信息 删除 失败 ! ):</script>" | 
09 } | 
On | 
11 if(isset($ GET[c) &&$ GET[c]!="){ // 更 改 订单 支付 状态 | 
12 $c=$_GET[c]: | 
13 让 GGc 一 'isfk){ | 
14 $adminDB->executeSQL("update tb_order set isfk = !isfk where id=" . $_GET[id] .| 
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| 15 } elseif ($c 一 'isfh) { 
| 16 SadminDB->executeSQL("update tb order set isfth = !isfh where id=" .$ GET["id'] . 
| "SSconnID): 

| 17 } elseif (Sc =— 'issh') { 

| 18 $adminDB->executeSQL("update tb order set issh = !issh where id=" .$ GETT'id] . 
,$connID): 

po 

| 2000) 
| 21 $sql="selectid, orderno. usermname, tel. goodsprice. yjprice. totalprice. isfk. isfh. issh, isqx 
| 22 from tb order order by addtime desc": // 构 建 查询 语句 


23 S$orders = $pageDB->pageData($sql, $connID, 20. $page): /对 订单 进行 分 页 查询 
24 $smarty->assign('orders'. $orders): 


5.13.2 ”订单 详细 信息 管理 


| 

单 击 订单 信息 列表 的 “查看 ”按钮 ， 将 显示 出 所 查看 订单 的 详细 信息 ， 其 运行 效果 如 
| 图 5.49 所 示 。 在 订单 的 详细 信息 页 面 中 可 以 显示 出 订购 人 的 信息 、 订 购 图 书 的 名 称 、 订 购 
| 图 书 的 数量 和 所 需 支付 的 各 项 价格 列表 。 


Mia; a010-05-)3 on nk ol 


性 到 ; 时 
13800000000 


素 仁 式 ; 更 付 在线 交 导 


加 各 次 市 电价 《元 】 。 评价 (元 】 订购 妆 生 5 本】 人 效 小 计 ( 元 ) 
《nm 开发 天 型 本 大 全 》 90 ra om z so 
《ce 不 设计 标 难 革 各 》 eg 59.00 1 5s9.0 
弃 因 1 30.00 元 


ETT EE 


图 5.49 订单 详细 信息 
| 在 实现 订单 信息 查看 功能 时 ， 首 先 通过 数据 库 管理 类 的 executeSQL0 方 法 查询 并 返回 
| 指定 订单 的 信息 ， 并 获取 商品 ID 串 和 商品 数量 串 信 息 ， 然 后 使 用 函数 explode0 将 商品 ID 
| 串 和 商品 数量 串 按照 分 阳 符 “@” 分 割 ， 并 将 分 割 的 结果 保存 到 数组 中 ， 最 后 通过 for 循 
| 环 语句 遍历 存放 商品 ID 的 数组 并 获取 相应 图 书 的 订购 信息 ， 该 过 程 在 admin-listorder.php 
| 文件 中 完成 。 上 述 过 程 的 代码 如 下 所 示 : 
代码 位 置 ， 配套 资源 \mr\05\admin -listorder.php 
| 
| 
| 
| 
| 


| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| TE 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 


01 SisShow = 下 ': 
02 if(isset($_ GET[f]) &&S$_GET[f] 一 'edit) { 


03 S$order = $adminDB->executeSQL("select id orderno, username, address、 
| 04 sex, yb., tel, idstr numstr, rectype. paytype., goodsprice. yjprice. totalprice. addtime. isfk. 
isfh. issh from tb_order 
| 05 where id=" .$_GET[id] . "". $connID): // 查 询 订 单 信息 
| 06 SarrayIds = explode((@' Sorder[ol[idstr]): 
| 07 $arrayNums = explode('@). $order[O]['numstr’]): 


| 
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08 S$arrayCarInfos = array(): | 
09 S$totalPrice = 0: 
10 for ($i = 0: $i < count($arrayIds): $i ++) { 
11 $bookid = $arrayIds[$i]: | 
12 if($bookid !=") { | 4 
13 StmpArray = arrayO: | 医 网 
14 $bookinfo = $adminDB->executeSQL("select id, bookname .oldprice, newprice | 
from tb_bookinfo | Mote 
15 where id=" . $bookid . "". $connID): // 查 询 图 书信 息 。 
16 S$tmpArray[id] = Sbookinfo[0][id]: /图 书包 | 
17 S$tmpArray['bookname'] = $bookinfo[O]['bookname']: // 图 书 名 称 | 
18 S$tmpArray['oldprice’] = $bookinfo[0]['oldprice']: /原价 | 
19 S$tmpArray[mewprice] = $bookinfo[0]['newprice']: 1/ 本 站 价 | 
20 S$tmpArray[mum'] = $arrayNums[$i]: 攻 /图 书 数量 | 
2 $tmpArray['smallTotalPrice] = $bookinfo[O]['newprice] * $arrayNums[$i]: // | 
图 书 单价 | 
22 Stotalprice += $tmpArray['smallTotalPrice']: /图 书 总 价 | 
23 array_push($arrayCarInfos, StmpArray): 
24 } | 
25 } | 
26 $smarty->assign('arrayCarInfos'. $arrayCarInfos): | 
27 $smarty->assign('order'", $order): | 
28 $isShow ="T': | 
2 | 
| 
| 
5.14 项 目 发 布 | 


在 发 布 明 日 网 上 书店 项 目 时 ， 可 能 会 出 现 一 些 问题 ， 为 了 便于 读者 学 习 ， 下 面 对 可 能 
出 现 的 一 些 问 题 进行 总 结 ， 并 且 给 出 具体 的 解决 方案 。 

1. 加 载 ADODB 类 库 | 

明日 网 上 书店 项 目 中 对 MySQL 数据 库 的 操作 应 用 的 是 ADODB 数据 库 抽象 层 ， 它 属 | 
于 第 三 方 组 件 ， 所 以 在 图 书 配套 资源 中 没有 提供 ADODB 类 库 ， 需 要 读者 自行 下 载 并 且 复 | 
制 到 本 项 目的 05\library 文件 夹 下 ， 命 名 为 adodb。 

如 果 没 有 载 入 ADODB 类 库 ， 直 接 运 行 本 项 目 时 将 输出 如 图 5.50 所 示 的 错误 信息 。 


ET 


图 5.50 没有 载 入 ADODB 类 库 


.233 . SA 


i 人 Pytp 项目 业 例 分 折 
oO ~ rr 


| 
2， 配置 数据 库 问题 


| 当 用 户 在 浏览 器 的 地 址 栏 中 输入 明日 网 上 书店 的 地 址 时 , 如 果 出 现 如 图 5.51 所 示 的 错 
误 提 示 信 息 ， 则 说 明 数 据 库 连 接 错 误 。 
出 现 数据 库 连 接 错误 ， 开 发 人 员 首先 需要 查看 数据 库 连 接 的 各 项 参数 是 否 正确 ， 如 数 
据 连 接地 址 、 数 据 库 服务 器 用 户 名 和 密码 等 。 打 开 该 项 目的 配置 文件 LzhConfig.ini， 查 找 
数据 库 配 置 模块 ， 如 图 5.52 所 示 。 


Er 和 过 ET 避 助 中 
E| 
3 [uatabase-config] 
ear dbType = musal 
bs Dwse, 有 和 人 i i 'db\drivers\adodb mysqgl. inc. php on lins 365 下 
| error: Gothoms 0 on a m0-obje 
| 中 Se mi eon ie Ase php en lins 24 
吉 lispupug - false 
BE mlm! C3 了 到 


图 5.51 数据 库 连 接 错 误 图 5.52 ”数据库 配 置 


从 图 5.52 中 可 知 ,导致 没有 正确 连接 数据 库 的 原因 是 管理 者 在 使 用 该 程序 时 , 将 数据 
库 服务 器 地 址 127.0.0.1 写成 127.0.0.11。 更 改 服务 器 地 址 后 再 运行 程序 ， 则 可 顺利 执行 。 


3， 程序 访问 路 径 设置 问题 
在 正确 设置 了 数据 库 服 务 器 、 数 据 库 和 密码 之 后 ,运行 程序 时 ， 却 出 现 了 如 图 5.53 所 


图 5.53 错误 的 运行 结果 


如 图 5.53 所 示 ， 网 站 中 所 有 的 图 片 都 没有 正常 显示 ， 查 看 图 片 的 属性 发 现 ， 访 问 图 片 的 
路 径 设 置 得 不 正确 ， 如 图 5.54 所 示 。 程序 在 本 机 中 的 运行 路 径 是 http://127.0.0.1/SOFT/22/, 但 
| 是 ， 图 片 的 访问 路 径 却 是 http://127.0.0.1/mr/22/， 这 就 是 问题 所 在 。 

解决 此 问题 的 方法 是 ， 修 改 项 目的 配置 文件 LzhConfig.ini， 定 位 到 [url-config]， 将 
| baseUrl 的 路 径 设 置 成 与 本 机 的 文件 访问 路 径 相同 ， 如 图 5.55 所 示 。 


示 的 结果 。 
| 访 放 曾 责 。 tL 上 【 芝 邓 】 [和 各 让] ET 
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图 5.54 图 片 路 径 设置 不 正确 


4. 程序 系统 设置 问题 


在 修改 了 配置 文件 中 的 访问 路 径 之 后 ， 再 次 运行 程序 ， 程 序 页 面 中 的 图 片 可 以 正常 显 
示 ， 但 是 ， 从 数据 库 中 读 取 的 图 书 封面 图 片 仍 无 法 正常 显示 。 查 看 图 片 属性 发 现 ， 依 然 是 
图 片 的 访问 路 径 不 正确 ， 如 图 5.56 所 示 。 

如 图 5.56 所 示 , 图 片 的 访问 路 径 是 http://192.168.1.190/bookshop/ upfiles/ bookimg/2009 
07031802067208.png。 但 是 程序 当前 的 路 径 应 该 是 http://127.0.0.1/SOFT/22/upfiles/ bookimg/ 


2009 07031802067208.png。 


解决 此 问题 的 方法 是 ， 登 录 明日 网 上 书店 的 后 台 管 理 系统 ， 进 入 “系统 管理 ”/“ 系 统 


[snarty-config] 

Itenplate_dir = vievs 

conpile dir = 1ibrary/snartu/conpile dir 
earhe_dir = 1ibrary/snarty/cache_dir 
config_dir - library/smarty/config_ dir 
caching = 9; 


信息 设置 ” 完成 对 程序 中 各 种 文件 访问 地 址 的 设置 操作 ， 如 图 5.57 所 示 。 


图 5.56 ”图片 访问 路 径 不 正确 
5. 客户 端 浏览 器 Cookie 设置 问题 
明日 网 上 书店 的 购物 车 模块 和 记录 登录 站 点 的 用 户 信息 都 是 通过 session 实现 的 


J 
图 5.55 设置 配置 文件 中 的 访问 路 径 
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图 5.57 系统 信息 设置 
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| 

果 客 户 端 浏览 器 禁用 了 Cookie 功能 ， 则 无 法 实现 将 商品 添加 到 购物 车 及 记录 用 户 的 登录 
| 信息 ， 所 以 在 运行 本 站 点 时 ， 如 果 发 现 上 述 状况 ， 可 以 开启 浏览 器 的 Cookie 支持 。 

| 下 面 以 正 浏 览 器 为 例 讲 解 如 何 开启 客户 端的 Cookie 支持 .首先 选择 正 浏览 器 菜单 栏 
| 中 的 “工具 ”一 “Intemet 选项 ”命令 ， 如 图 5.58 所 示 。 


EE 
地 址 1D) | 大 hitnejh.0.0. tbookshonlnd 。 即 伞 和 新 闻 (0 


会 说 有 让 页 。 赂 季 4 欢 好 胡 E 


(EY KEMEEN: 


ww-mrboo 


计 评 作 更 职 设置 。 4 
图 5.58 ”打开 Internet 选项 对 话 框 


此 时 ， 将 弹出 如 图 5.59 所 示 的 对 话 框 ， 选 择 该 对 话 框 的 “隐私 ”选项 卡 ， 从 图 中 可 知 
这 里 禁用 了 Cookie 支持 ， 所 以 应 该 适当 开发 Cookie 功能 或 单 击 图 中 的 “默认 ”按钮 。 


钊 疯 | 安全 “隐秘 | 加 | 渤 接 | 程 订 | 而 多 | 
es 
tt 

” 胆 止 所 有 Ceokie 


日 加 四 于 2 下， 下 


| 
拖 搜 这 里 开发 Cookie 


9 万 明 上 放出 密 口 中 :1 


职 滑 本 HE 
图 5.59 Intemet 选项 对 话 框 


一 个 优秀 的 Web 项 目 除了 能 够 安全 稳定 地 运行 外 , 还 需要 让 管理 者 能 够 熟练 地 对 其 进 

行 管理 ， 所 以 在 完成 项 目的 各 项 功能 后 还 需要 为 使 用 者 编写 用 户 使 用 手册 。 本 节 将 以 图 书 
小 类 信息 管理 过 程 为 例 ， 讲 解 用 户 使 用 手册 的 编程 方法 。 

(1) 打开 后 台 管 理 员 登录 页 面 后 , 在 用 户 登 录 表 单 中 输入 用 户 名 (mr)、 密 码 (mrsoft) 
和 验证 码 信息 ， 如 图 5.60 所 示 ， 单 击 表单 的 “登录 ”按钮 ， 如 果 登 录 信息 正确 则 可 成 功 登 
录 后 台 。 

(2) 管理 员 登 录 后 可 以 从 左 侧 导 航 栏 中 选择 要 管理 的 模块 ， 这 里 选择 “图 书 类 别管 
理 ”， 将 列 出 所 有 与 该 模块 有 关 的 管理 选项 ， 如 图 5.61 所 示 。 

“0s 


| 5.15 ”用户 使 用 手册 
| 
| 
| 
| 
| 
| 
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| 鳃 

[4500 | 有 下 | 
Note 
图 5.60 后 台 管理 员 登 录 表单 
| 
| 
| 
| 
| 
| 
图 5.61 选择 要 管理 的 模块 | 
(3) 单 击 图 5.61 中 的 图 书 类 别管 理 模块 的 “图 书 小 类 别管 理 ” 超 链接 ， 将 出 现 如 | 
图 5.62 所 示 的 添加 类 别 表单 ， 管 理 员 可 以 在 该 表单 中 添加 图 书 小 类 信息 。 | 
pa mr ma 
| 
| 
ee le | -RR 3 本 

| 


| imi ll 3 
图 5.62 添加 类 别 信息 
(4) 单 击 图 5.62 所 示 图 书 小 类 添加 表单 上 面 的 “浏览 图 书 小 类 信息 ”按钮 ， 将 出 现 
如 图 5.63 所 示 的 小 类 信息 列表 ， 该 列表 以 分 页 的 形式 展现 出 图 书 小 类 的 关键 信息 。 


wy .< 


Te 人 可 人 Pytp 项 目 娄 例 分 析 


| 图 5.63 信息 列表 页 

(5) 单 击 图 5.63 所 示 图 书 小 类 信息 列表 中 指定 类 别 后 的 编辑 图 标 ， 将 出 现 该 类 别 的 
| 编辑 表单 ， 如 图 5.64 所 示 ， 在 该 表单 中 对 小 类 信息 进行 编辑 后 单 击 “ 更 改 ”按钮 即 可 完成 
对 指定 小 类 信息 的 更 改 操作 。 


| 
= 可 
IE cc » EE 


| 


Ws ma | 
更 改 类 别 信息 表 到 
图 5.64 编辑 信息 页 面 


(6) 单 击 图 5.64 中 指定 类 别 后 的 删除 图 标 则 首先 弹出 删除 确认 对 话 框 ， 如 果 管 理 员 
确认 删除 ， 则 可 以 将 该 类 别 信息 删除 ， 反 之 ， 则 不 进行 任何 操作 ， 如 图 5.65 所 示 。 


ER 


确认 删除 提示 框 
ah 7 下 


| 图 5.65 删除 信息 提示 框 
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本 章 小 结 


本 章 主要 介绍 明日 网 上 书店 网 站 的 开发 过 程 ， 详 细 讲 解 了 项 目 设计 思路 、 功 能 结构 、 会 一 
文件 夹 架 构 、 数 据 库 设 计 及 具体 功能 开发 。 通 过 学 习 ， 读 者 可 以 了 解 以 下 内 容 。 Tte 

(1) ADODB 数据 库 抽 象 层 操 作 MySQL 数据 库 。 

(2) 通过 面向 对 象 的 编程 方式 对 常用 方法 进行 封装 ， 包 括 数据 库 连 接 类 、 数 据 库 管 
理 类 、Smarty 模板 的 配置 类 、 分 页 类 、 购 物 车 类 以 及 常用 工具 类 。 | 

(3) Smarty 实现 网 页 的 动静 分 离 。 | 

(4) FCKediter 在 线 编辑 器 的 应 用 。 

(5) PHP 伪 静 态 技术 。 
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办 公 自 动 化 系统 


( PHP+Smarty+MS SQL Server 2000+PDO 实现 ) 
合 m 自学 视频 、 源 程序 : 配套 资源 mm6\ 


办 公 自 动 化 (Office Automation，OAJ 系统 指 实 现 办 公 室内 事务 性 此 务 *.--| 删除 的 内 容 : 宇 
的 自动 化 。 删除 的 内 容 : 英文 原 称 
办 公 自 动 化 没有 明确 的 定义 ， 最 普遍 的 说 法 是 : 凡是 在 传统 的 办 公 室 中 条 删除 的 内 容 : 缩写 为 


用 各 种 新 技术 、 新 机 器 、 新 设备 从 事 办 公 业 务 ， 都 属于 办 公 自 动 化 领域 。 


办 公 自 动 化 系统 与 办 公 自 动 化 在 概念 上 存在 一 定 的 差别 。 办 公 自 动 化 通常 、 
指 办 公 室 中 配备 具有 自动 化 功能 的 设备 ， 这 些 设备 能 使 某 些 办 公 活 动 自动 化 或 


删除 的 内 容 : ， 办 公 自 3 


六 阁 计 的 :下 0. 文昌 入 
最 小 值 16. 5 


实现 基 个 单位 业务 的 自动 化 处 理 ; 而 办 公 自 动 化 系统 则 是 在 办 公 室 自动 化 功能 a 
的 基础 上 发 展 起 来 ， 以 办 公 自 动 化 技术 为 主体 ， 同 人、 组 织 、 制 度 、 环 境 等 相 
结合 的 完整 的 系统 。 
通过 阅读 本 章 ， 读 者 可 以 学 到 : 
PI 功能 设计 思路 
WI 数据 库 设计 
PI 页 面 布 局 中 的 框架 布局 
”使 用 递归 函数 制作 多 级 下 拉 菜 单 删除 的 内 容 : 
I 系统 日 志 的 实现 区 和 下 的 :本 
m Smarty 模板 技术 0 克 让 局; 全 全 玉 
让 _PDO 操作 MS SQL Server 数据 库 或 编号 
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6.1 功能 设计 思路 


6.1.1 功能 阐述 | 


见 配 套 资源 中 的 源 程序 。 | 
前 台 登 录 页 面 如 图 6.1 所 示 ， 该 页 面 用 于 实现 对 用 户 登录 的 用 户 名 和 密码 进行 验证 。 
企业 信息 页 面 如 图 6.2 所 示 ， 该 页 面 用 于 显示 企业 文化 和 各 种 规章 制度 。 


\ 


MN 


图 6.2 企业 信息 (规章 制度 ) 页 面 


i 
刘 2 @ 用 户 名 : 区 一 ] 害 友 [eee 中 EE 
一 一 一 


有 i | 


图 6.3 个 人 计划 页 面 图 6.4 后 台 登 录 页 面 


如 图 6.6 所 示 ， 该 页 面 用 于 对 功能 使 用 权 进 行 分 配 。 


删除 的 内 容 : 的 管理 
删除 的 内 容 : 对 

NN 删除 的 内 容 : 的 管理 、 

、[ 删除 的 内 容 : 的 
[出 除 的 内 容 : 自动 化 
[出 除 的 内 容 : 、 
[开除 的 内 容 ; 进行 管理 
[出 陈 的 内 容 : 对 

\ | 删除 的 内 容 : 、 

人 囊 除 的 内 容 : 功能 

1 刷 除 的 内 容 : ， 


删除 的 内 容 : 用 户 的 


图 6.5 职员 管理 页 面 


6.1.3 功能 结构 


根据 系统 分 析 ， 


人 和 和 人 和亲 和 人 人 人 区 人 和 


者 好 


6.6 权限 分 配 页 面 


6.7 问 易 办 公 自 动 化 系统 前 台 功 能 结构 图 


--] 带 格式 的 : 字体 : Time 
Roman 


必 \、 | 删除 的 内 容 ;下面 

NNN\ 出 除 的 内 容 : 。 

第 格式 的 ;字体 :Tine 
Roman 

必 T 副 格式 的 : 字体 (中 


,| Times New Roman， (中 


改 儿 宋体 ， (国际 ) 宋体 
人 » 
| 带 格式 的 : 字体 : ( 默 


小 | Times New Roman， (中 


PE 
\ | 带 格式 的 : 字体 : ( 默 
1| Times New Roman， (中 . 
儿 宋 体 ，( 国 际 ) 宋体 

人 二 一 一 一 
带 格式 的 : 字体 : Time 
Roman， 检 查 拼写 和 语 漳 
上 删除 的 内 容 : 问 是 办 公 
! 系统 前 台 功 能 结构 图 如 
所 示 。 
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账号 权限 


用 户 组 设置 站 


权限 分 配 


6.1.4 文件 夹 组 织 结构 
系统 功能 结构 设计 完成 后 ， 接 下 来 就 要 设计 网 站 的 文件 夹 结构 了 ， 合 理 的 文件 夹 结构 | 


系统 的 文件 夹 组 织 结构 如 图 6.9 所 示 。 


[ER 
E wa 


包 
EE 
2 
= 
= 钴 
和 
日 
中 


6.9 问鼎 办 公 自动 化 系统 文件 夹 组 织 结构 | 
. 243 . 、 


人 Pie 项 目 业 例 分 析 


6.2 数据 库 设计 
> | 6.2.1 数据 库 设计 结构 


基于 目前 的 系统 开发 ， 没 有 数据 库 的 支持 根本 是 无 法 想象 的 ， 问 是 办 公 自 动 化 系统 更 
是 使 用 了 大 量 的 数据 表 来 存储 数据 。 本 系统 采用 MS SQL Server 2000 数据 库 ， 这 对 于 一 个 


企业 的 内 部 办 公 自 动 化 管理 系统 已 经 足够 。 在 本 系统 中 创建 了 一 个 数据 库 db_offce， 一 共 _- - -删除 的 内 容 : 完全 
包含 J4 个 数据 表 ， 如 图 6.10 所 示 。 _ -一 删除 的 内 容 : 13 


图 6.10 db_office 库 中 的 数据 表 列表 


| 国 也 jgroup 一 一 一 一 一 一 一 一 一 一 一 一 一 用 户 $8 管 理 表 

| 国 busers 一 由 

| 国耻 depat 一 一 一 一 一 一 一 一 一 一 一 一 部 站 管理 表 

| 国 tbjist 功能 列表 
国 bbiglit 一 一 一 一 一 一 一 一 一 一 一 #3 灶 

| 国 了 bperson 一 一 一 一 一 一 一 一 一 一 一 一 人 事 列表 

| 国 了 bplan 一 一 一 一 一 一 一 一 一 一 一 计划 睦 

| 国 tbjiss. 审核 列表 

| 国 tbcompary 一 一 企业 信息 列表 

| 国 tb_superson 一 一 一 一 一 一 一 一 一 一 一 一 优秀 员工 列表 

| 国耻 setup 一 一 一 一 时间 列表 

| 国 了 bregister 一 党 录 列 表 

| 国 tb.ye 意 风 箱 表 

| 图 tbcontroler~- 和 管 昌 员 列表 

| 

| 


6.2.2 ”数据 表 设 计 结 构 
限于 简 由 tel 了 的 内部 
1. tb_users (用 户 列表 ) 删除 的 内 容 : 表 


| 用户 列表 主要 用 于 存储 职员 的 姓名 、 性 别 等 私人 信息 ， 以 及 部 门 、 工 作 组 等 与 公司 相 
关 的 公共 信息 。 该 数据 表 结 构 如 表 CI 所 示 。 “删除 的 内 容 : 图 


| 字段 类 型 说 明 
| 大 int 用 户 ID 
| UL_USeT Varchar 用 户 名 
| Upwd Varchar 密码 
| u_ name varchar 真实 姓名 
| Usex varchar 性 别 
| u_birth varchar 生日 
| U_address Varchar 地 址 
| utel varchar 电话 
u email varchar 下 mail 地 址 a 删除 的 内 容 : 
| u depart varchar 部 门人 D 
is on varchar 权限 
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2. tb_person (人 事 列 表 ) 
人 导 


| 类 型 | 额外 | 
| 


auto_increment 


u_member Varchar | | 


表 6.4 部 门 列表 


auto increment 


额 外 


部 门 名 称 


上 层 部 门 


管理 员 列 表 用 于 存储 管理 员 信息 ,包括 态 、 管 理 员 名 称 、 密 码 和 权限 级 别 信息 等 。 CT 


表 结 构 如 表 6.5 所 示 。_ 
字 段 类 型 额 外 说 阴 
id int auto_increment 信息 ID 
manager varchar 50 管理 员 名 称 
mana_pwd varchar 50 管理 员 密 码 
purview int 4 权限 级 别 
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- -六 删 除 的 内 容 : 图 


~ 人 Pitp 项 目 灶 例 分 析 


6. tb list ( 功能 列表 ) 


-了 { 删除 的 内 容 : 图 


6.2.3 ”连接 数据 库 


| 本 项 目 封 装 数据 库 连 接 和 操作 类 ， 对 MS SQL Server 2000 数据 库 进行 操作 ， 分 别 是 
| ConDB 数据 库 连接 类 ， 实 现 通 过 PDO 连接 MS SQL Server 2000 数据 库 ，AdminDB 数据 
| 库 管 理 类 ， 使 用 PDO 类 库 中 的 方法 执行 对 数据 库 中 数据 的 查询 、 添 加 、 更 新 和 删除 操作 。 


| 人 码 如 下 : 
| 代码 位 置 ， 配套 资源 \mr\06\system\system.class.inc.php 
| 01 classConmnDB{ // 数 据 库 连接 类 
| 02 var $dbtype: 
| 03 Var $host:; 
| 04 Var $user; 
| 05 var $pwd: 
06 Var $dbname; 
| 07 function ConnDB($dbtype, $host, $user,$pwd,$dbname) { /构造 方法 
| 08 Sthis->dbtype=$dbtype: 
| 09 Sthis->host=$host: 
| 10 S$this->user=$user: 
| 11 Sthis->pwd=$pwd: 
| 了 Sthis->dbname=$dbname:; 
| 13 } 
| 14 function GetConnIdO{ // 实 现 数据 库 的 连接 并 返回 连接 对 象 
| jE; if($this->dbtype=—"mysql" || $this->dbtype=="mssq1"){ 
| 16 $dsn="$this->dbtype:host=$this->host:dbname=$this->dbname":; 
mn }else{ 
18 $dsn="$this->dbtype:dbname=$this->dbname": /连接 MYSOL 数据 库 。 __- -{ 删除 的 内 容 : Oracle 
| 19 } 
| 20 try{ 
| 2 $conn = new PDO($dsn, $this->user, Sthis->pwd): // 初 始 化 一 个 PDO 对 象 , 就 是 创建 了 
| 数据 库 连 接 对 象 $pdo 
| 2 return $conn: 
| 23 } catch (PDOException $e) { 
24 die ("Error!: " . $e->getMessage() . "<br/>"): 
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25 } | 


26 } | 
2 | 

28 classAdminDB{ // 数 据 库 管 理 类 : 

29 function ExecSQL($sqlstr, $conn){ | 全 站 
30 $sqltype=strtolower(substr(trim($sqlstD.0.6)): 1 
31 Srs=$conn->prepare($sqlstr): /准备 查询 语句 we | 
32 Srs >execute(); // 执 行 查询 语句 ， 并 返回 结果 集 。 其 和 3 
33 if($sqltype—"select"){ | 

34 $array=S$rs->fetchAll(PDO::FETCH_ASSOC): /获取 结果 集中 的 所 有 数据 | 

35 if(count($array)—0 | $rs—false) | 

36 Teturn false: | 

37 else ! 

38 Teturn $array; | 

39 jelseif ($sqltype 一 "update" || $sqltype 一 "insert" | $sqltype=—"delete"){ | 

40 if($rs) | 

41 Teturn true: | 

42 else 

43 Teturn false: 

44 } ! 

45 } | 

46 } | 


6.3 公共 模块 设计 


函数 文件 。 
6.3.1 Smarty 类 库 的 封装 


在 Smarty 模板 配置 类 SmartyProject 中 配置 Smarty 模板 文件 、 编 详 文件 、 配 置 文件 等 | 
文件 路 径 ， 首 先 要 卉 入 Smarty 类 库 ， 然 后 炙 素 Spurty 关 ， 完 成 本 置换 作 ， 代码。 - | 


01 -<?php 
02 require("libs/Smarty.class.php"): // 包 含 模板 文件 
03 class SmartyProjectextends Smarty{ // 定 义 类 ， 继 承 模板 类 | 
04 function SmartyProjectO{ /定义 方法 | 
05 Sthis->template_dir = "./system/templates/": // 指 定 模 板 文件 存储 位 置 | 
06 Sthis->compile_dir = "./system/templates_c/": // 指 定编 译文 件 存储 位 置 | 
07 Sthis->config dir="./system/configs/": // 指 定 配置 文件 存储 位 置 | 
08 Sthis->cache_dir ="./system/cache/": // 指 定 缓存 文件 存储 位 置 | 
09 | 
10 } | 
! 
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6.3.2 类 的 实例 化 


鲜 | | 在 system.inc.php 文件 中 ， 通 过 require 语句 包含 system.smartyinc.php 和 system.class. 


| inc.php 文件 ， 执 行 类 的 实例 化 操作 ， 并 定义 返回 对 象 。 完 成 数据 库 连 接 类 的 实例 化 后 ， 调 


对 象 。 代 码 如 下 : 
代码 位 置 ， 配 套 资源 \mr\06\system\system.inc.php 


| 01 <?php 
| 02 require("system.smarty.inc.php"): // 包 含 Smarty 配置 类 
| 03 require("system.class.inc.php"); // 包 含 数据 库 连 接 和 操作 类 
| 04 ”$connobj=new ConnDB("mssql","localhost","sa",""."db_office"):// 数 据 库 连 接 类 实例 化 
| 05 $conn=$connobj->GetConnId0:; // 执 行 连接 操作 , 返回 连接 标识 
| 06 $admindb=new AdminDBO: // 数 据 库 操作 类 实例 化 
| 07 S$usefun=new UseFun0: // 使 用 常用 函数 类 实例 化 
08 $smarty=new SmartyProjectO: // 调 用 smarty 模板 


09 function unhtml($params){ 

10 extract($params): 

对 $text=$content; 

12 global $usefun: 

13 return $usefun->UnHtml($text); 


| T4000 
| 15 $smarty->register function("unhtml","unhtml"); // 注 册 模板 函数 
| 16 。 fnnction charsetUTF8($params) { // 创 建 模板 函数 
| 17 extract($params); // 读 取 数 据 

18 $str=iconv("gb2312"."ut 人 8".Stext): 
| 19 Teturn $str // 返 回 截取 结果 
| 20  } 
| 21 $smarty->register function("Util", "charsetUTF8"): // 注 册 模 板 函 数 
| 22 0 00 


| 6.3.3 JavaScript 脚本 


在 问 是 办 公 自动 化 系统 中 ，JavaScript 脚本 一 般 用 于 表单 元 素 验 证 ， 如 判断 Test 文本“ - - 才 弄 除 的 内 容 : text 
杠 输 入 是 否 为 空 。 输 入 格式 是 否 符合 标准 等 。 ”一 - 才 贡 除 的 内 容 : ， 


(1) 验证 函数 ， 判 断 表单 元 素 是 否 为 空 。 如 果 为 空 ， 则 返回 false， 并 将 光标 焦点 定 
| 位 到 出 问题 的 表单 元 素 。 程 序 代码 如 下 : 
| 代码 位 置 : 配套 资源 mr0Gjsvclient_ jsjs 


01 /后 台 登 录 界 面 验证 脚本 
02 function checkO{ 


03 这 login usermame .value 一 ""){ /判断 用 户 名 是 否 为 空 
04 alert(" 请 输入 用 户 名 !!"): 
05 login.username.focus0; /将 光标 焦点 定位 到 该 表单 元 素 
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C4 | 
06 return false: | 
07 } | 
08 if(login.pwd.value—""){ // 淹 断 用 户 密码 是 否 为 空 | 
09 alert(" 请 输入 密码 !1"); // 如 果 为 空 ， 则 弹出 提示 框 | 
10 login.pwd .focusO; // 将 光标 焦点 定位 到 该 表单 元 素 | 全 7 
而 return false: // 返 回 false | ~ 
12 | 
13 } } MNote 


(2) 删除 确认 ， 当 要 执行 删除 操作 时 ， 使 用 JavaScript 脚本 文件 进行 确认 ， 以 免 因 为 | 
误 操作 而 引起 不 必要 的 损失 。 程 序 代码 如 下 : | 


代码 位 置 : 配套 资 源 \mx\06js\client jsjjs | 


01 function cfmO{ | 
02 if(confirm(' 确 认 要 删除 吗 ? ')) // 选 择 框 函数 | 
03 return true: /如果 选择 确认 ， 则 返回 tmue， 继 续 执行 | 
04 else | 
05 return false; // 否 则 ， 返 回 false 

0 } 


6.3.4” 自 定义 函数 


在 inc 文件 夹 下 ， 有 两 个 主要 文件 ，chec.php 和 calenderphp。 其 中 ，chec.php 文件 是 | 


权限 检查 文件 , 问鼎 办 公 自动 化 系统 每 个 页 面 都 要 引用 , 用 于 对 登录 用 户 的 权限 进行 判 电 ; _} -- 


calenderphp 文件 中 封装 了 一 个 日 历 。 | 


限 级 别 的 限制 ， 随 意 访问 重要 的 资源 和 数据 ， 那 么 只 能 说 明 这 是 个 完全 失败 的 系统 。 


{删除 的 内 容 : . 


: (中 3 
机 


人 
带 格式 的 : 字体 : (中 3 
体 


7 


1 \ 一 
checphp 文件 的 代码 如 下 : NN 
代码 位 置 ， 配套 资源 \mr\06\inc\chec.php | 人 { 带 格式 的 ， 字体 (中 
01 <?php | I 
02 session startO; // 初 始 化 session 变量 | 作 帝 格 式 的 : 字体 : (中 3 
03 @ if!isset($ SESSION['u name'])) /验证 用 户 名 是 否 为 真 En Dea 
04 echo "<script>alert( 您 无 权 访 问 "):location="index.php':</script>"; : 天 格式 的 : 字体 : (中 3 
05 @ ifs SERVER['HTIP REFERER']—"") | 
06 echo "<script>alert( 本 系统 不 允许 从 地 址 栏 访 问 ):window.closeO:</script>": | 删除 的 内 容 : 才 可 以 
07 > | 
! 
多 关键 代码 外 了 删除 的 内 容 : 关键 代 
@ isset0 函 数 : 用 来 判断 8 2 hd 
不 则 返回 人 alse， 其 中 SESSION['u_name ] 是 用 户 登录 验证 通过 后 创建 的 ， 如 果 没 有 登录 或 SESSION 超 ddl 
时 ， 那 么 就 会 提醒 用 户 没有 权限 。 、、 1 删除 的 内 容 : 者 
@@$_ SERVER[HTTP REFERER]: 系统 预定 义 变量 ， 存 储 的 是 上 一 页 的 URL 地 址 . 该 判断 的 作用 是 _ “并 带 格式 的 : 字体 : 非 加 
防止 当前 用 户 访问 不 属于 自己 权限 内 的 网 页 。 | “十 删除 的 内 容 :这 个 
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。 型 除 的 内 容 : . 
i 
行 缩 进 : ”0.74 厘米 


[而 -ans 


r 


图 6.11 生成 的 日 历 效果 


6.4 ”前台 首 页 设计 


| 在 calenderphp 文件 中 ， 通 过 JavaScript 脚本 和 PHP 脚本 封装 了 一 个 日 历 ， 具 体 代码 
| 请 参考 本 书 配套 资源 。 其 生成 的 日 历 效果 如 图 6.11 所 示 。 


| 6.4.1 


前 台 首 页 概述 


根据 用 户 对 各 个 功能 模块 的 使 用 频率 和 重要 程度 ， 本 系统 的 首页 面 中 要 显示 
要 有 3 部 分 。。 


一 一 


(2) 网 站 左 侧 导 航 栏 : 包括 各 个 管理 模块 及 分 类 。 


企业 信息 模块 : 
四 ”企业 绩效 模块 : 
回 _ 人 事 消息 模块 
四 审核 批示 模块 : 


四 个 人 计划 模块 : 
回 _ 职 员 天 地 模块 : 
(3) 网 站 主 显示 区 : 


所 示 。 
J 


包括 公司 简介 、 规 章 制度 、 组 织 结构 和 企业 管理 。 
包括 任务 绩效 、 质 量 绩效 和 绩效 评定 。 
包括 企业 公告 、 活 动 安排 和 消息 管理 。 


包括 发 布 审核 和 批示 审核 。 
考勤 管理 模块 : 


包括 职员 浏览 、 意 见 箱 和 个 人 设 定 。 


(1) 网 站 首页 导航 栏 : 显 
登录 和 退出 登录 。， 


的 模块 主 


二 删除 的 内 容 : 、 


删除 的 内 容 : ， 
删除 的 内 容 : 。 


LTT 
-的 内 下、 


包括 上 下 班 登 记 、 病 事假 登记 、 加 班 登记 和 考勤 设置 。 
包括 工作 反馈 、 周 计划 、 月 计划 、 年 计划 和 任务 计划 。 


A 
< 


LT 
‘全 格式 的 :正文 ， 绢 过 


删除 的 内 容 : 包括 
删除 的 内 容 : 、 
删除 的 内 容 : 


、 中 格式 的 :项目 符号 和 
格式 的 : 正文 并 列 一 


行 缩 进 : ”0.74 厘米 


/ -- 带 格式 的 : 项 目 符号 和 


删除 的 内 容 : 下 面 看 一 
一 


删除 的 内 容 : 案例 


删除 的 内 容 : ， 该 首页 
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在 仙 导航 栏 a 时 ! 
日 起 NE <a EM #4 EF 人 
321 月 4600 。 觅 4 下文 轩 计划 3041 二 月 11426 亲人 过于 8。 者 村 世 沙 和 
2011 二 月 24000 。 进 和 对 本 看 4 这 月 计 划 
2011 = 月 14040 元 可 看 全 司 计 划 
0 二 月 4c0 进一步 下 站 全 六 年 计划 
2011 二 月 1590 莉 旬 豆 看 全 六 有 天蓝 


图 6.12 问 是 办 公 自 动 化 系统 前 台 首页 
6.4.2 前台 首页 框架 技术 


十 删除 的 内 容 : 使 用 


二 
_(1 框架 布局 格式 TN 


框架 布局 的 格式 很 简单 ， 只 要 几 行 代码 即 可 ， 常 用 的 格式 如 下 : r 
<html> | 


EE 


</noframes> | 
</html> | 
其 中 ，<frameset> 和 <frame> 标 签 是 框架 集 标 记 ， 而 <noframes> 标 签 是 为 了 防止 浏览 
不 支持 框架 而 实行 的 一 种 补救 措施 。 如 果 浏览 器 不 支持 框架 集 ， 就 会 执行 <noframes> 标 记 | 
里 的 内 容 ， 让 用 户 能 够 正常 浏览 网 页 。 


。251 。 S 


洲 癌 是 肌 前 : 0 磅 ， 股 


一 


删除 的 内 容 : . 


， 值 、 说 明和 应 用 举例 ， 如 表 6.7 所 示 。 


行 缩 进 : 0.74 厘米 


”| 删除 的 内 容 : FRAMESF 
记 


表 6.7 ”框架 集 的 常用 属性 


属性 名 称 属性 说 明 应 用 举例 
在 水 平方 向 上 将 浏览 器 分 割 成 多 个 窗口 ， | <frameset cols="25%6.100.*" > 
cols 取 值 有 3 种 形式 : 像素 、 百 分 比 (%) 和 相 | <frame></frame> 
对 尺寸 (*) </frameset> 
<frameset rows="25%,100,.*" > 
在 垂直 方向 上 将 浏览 器 分 割 成 多 个 窗口 ， <frame> 
pi 取 值 和 cols 类 似 ， 也 是 3 种 形式 <frame> 
</frameset> 
<framset cols="25%,*" cols="*" 
Pe 指定 框架 周围 是 否 显示 边框 , 取 值 为 1 ( 显 | frameborder="0"> 
示 边 框 ， 默 认 值 ) 或 0 (不 显示 边框 7 
</frameset> 
<framset cols="25%,*" cols="*" 
i 指定 框架 之 间 的 间隔 ， 以 像素 为 单位 。 默 | framespacing="1"> 
认 是 无 间隔 的 
</frameset> 
<framset cols="25%,*" cols="*" 
i 指定 边框 的 宽度 ，frameborder 属 性 为 1 时 | frameborder="1" border="5"> 
该 属性 才 有 效 
</frameset> 
9 加 性 人 
、\、、 【人 沙 间 距 段 前 : 0 磅 
使 用 ame> 标 签 可 以 设置 椎 架 的 属性 ， 包 括 框 如 的 各 称 、 框 如 是否 包 含 滚动 条 以 及 、 、、 员 了 的 内 窜 ”一 
在 框架 中 显示 的 网 页 等 。 框 架 的 常用 属性 及 说 明 如 表 6.8 所 示 。 于 珊 除 的 内 容 :FRAME 和 


表 6.8 框架 的 常用 属性 


ee 
`、]| 删除 的 内 容 : FRAME 村 


属性 名 称 属性 说 明 “其 除 的 内 容 :其 
name 指定 框架 的 名 称 
sr 指定 在 框架 中 显示 的 网 页 文件 〈 包 括 HIML、PHP、JSP 等 网 页 文件 ) 
frameboder 。 ”| 指定 框架 周围 是 否 显示 边框 ， 取 值 为 1 (显示 边框 ,默认 值 ) 或 0 (不 显示 边框 ) -| 删除 的 内 容 :为 
noresize 可 选 属性 ， 若 指定 了 该 属性 ， 则 不 能 调整 框架 的 大 小 
scrollin: 指定 框架 是 否 包含 滚动 属性 可 以 是 yes (有 ) 、no (没有 ) 或 auto (自由) | 删除 的 内 容 : 。 


ws 


[天 队 的 内 容 。 。 
出 队 的 内 容 : 和 
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6.4.3 ”前 台 首 页 的 实现 过 程 | 


问 易 办 公 自 动 化 系统 的 前 台 首 页 采用 二 分 栏 结 构 布局 ， 二 分 栏 布局 的 特点 是 简洁 、 大 | 
气 、 个 性 鲜明 ， 其 框架 设计 依据 其 内 容 形 式 的 变化 而 灵活 多 变 ， 结 构 简 练 ， 非 常 符合 办 公 | 


代码 位 置 ， 配套 资源 nr06\pub_main.php 


01 ©@ <framesetrows="111,*" cols="*" frameborder="no" border="0" framespacine="0"> 

02 四 <frame src="top.php" name="topFrame" scrolling="No" noresize="noresize” id= 
"topFrame" title="topFrame" /> 

03 © <framesetrows="*" cols="220,*" framespacing="0" frameborder="not" border="0"> | 

04 @<frame src="left.php" name="leftFrame" scrolling="auto" noresize="noresize" id="leftFrame" | 
tile="leftFrame" /> | 


05 日 <frame src="main.php" name="mainFrame" scrolling="auto" id="mainFrame" | 
title="mainFrame" /> | 
06 </frameset> 


09 <body> | 
10 </noframes> | 


) 
" | 删除 的 内 容 : 关键 代码 有 
"  “-( 咯 格式 的 
| 


@ rows="*" cols="220,*": 定义 下 部 左 侧 框架 . 

@ src="leftphp": 定义 左 侧 框架 显示 的 页 面 。 

@@ src="main.php": 定义 中 间 主 框架 显示 的 页 面 。 
@ <noframes>: 当 浏览 器 不 支持 框架 集 时 的 内 容 。 


6.4.4 ”定义 项 部 框架 内 显示 的 页 面 


顶部 框架 内 容 的 设计 由 两 个 文件 组 成 :一 个 是 动态 PHP 文件 top.pbp:_ 另 一 个 是 模板 _| -删除 的 内 容 : ， 
文件 top html。 在 top php 文件 中 ， 载 入 类 的 实例 化 文件 ， 并 且 指定 模板 页 ， 其 代码 如 下 : “| “删除 的 内 容 : ， 


代码 位 置 ， 配套 资源 \mi\06\top.php | 


0 -<?php | 
02 session start(: // 初 始 化 session 变量 | 
03 include("system/systeminc.php"): // 载 入 类 的 实例 化 文件 | 
04 $smarty->display("top.html"); // 指 定 模 板 页 

05 > 


在 模板 文件 top.html 中 , 创建 “首页 ”“ 重 新 登录 ”和 “退出 ”的 超 链接 , 通过 Smarty 
中 的 {$smarty.session} 方 法 获取 session 的 值 ， 通 过 Smarty 中 的 {$smarty.now} 方 法 和 
date_format 函数 格式 化 输出 系统 的 当前 时 间 ， 其 关键 代码 如 下 : 


。253 。 \ 
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代码 位 置 : 配套 资源 \mr\06\system\templates\top.html 


| 01 <table width="1003" height="111" border="0" cellpadding="0" cellspacing="0" background=- 
| "images/bg 02.jpg"> 


袋 内 | 02 <tr> 
| 03 <td height="86" colspan="3" rowspan="2">&nbsp:</td> 
| 04 <td height="29" align="center"><a href="pub main.php" target= 
Note 国 _parent"> 首 页 </a></td> 
| 05 <td height="21" align="center"><a href="index.php" target=" parent"> 重 
新 登录 </a></td> 
| 06 <td height="21" align="center"><a href="logout.php" target=" parent"> 
| 退出 </a></td> 
| 07 <td height="21">&nbsp;</td> 
| 08 </tr> 
09 <tr> 
| 10 <td width="55" height="57" align="center" valign="middle">&nbsp:</td> 
| 11 <td width="102" align="center" valign="middle">&nbsp:</td> 
| 2 <td width="52" align="center" valign="middle">&nbsp:</td> 
| 13 <td width="14" align="center" valign="middle">&nbsp:</td> 
| 14 </> 
| 15 <tr> 
| 16 <td width="290" height="25">&nbsp:</td> 
| 17 <td width="220"><font color=08 "#0f0f0">{$smarty.session.n_name} </font> </td> 
| 18 <td width="270" ><font color="#HOfOf0">{Util text=Ssmarty.session.u_depart}</font></td> 
| 19 <td height="25" colspan="4" align="center" valign="middle"><b><font color="#f0f0f0"> 
| 2 0 3 EE {Ssmarty.nowldate format:"%0Y-%m-%d 9%H:%M:%S")</font></b></td> 。。__- - {删除 的 内 容 : @ 
| 21 </t> 
| 22 </table> 
Ah 关键 代码 解 村 
上 ne 
Smarty 模板 中 的 date_ format 函数 ， 格 式 化 从 函数 strftime0 获 得 的 时 间 和 日 期 。 其 应 用 示例 如 下 : *、、- -| 删除 的 内 容 : 关键 代码 
si tid el eds 
{$smarty.nowldate_format:"%A, %B %e, %Y":$times} 带 格式 的 : 代码 - 楷 ， 纪 
团 Ssmarty.now: 传递 给 date_format 的 数据 。 芒 条 数 可 以 是 在 PHP 动态 页 中 定义 的 日 期 、 时 间 模 、“、| 身 式 的 ”TC 而 
| 板 变量 ， 也 可 以 使 用 Smarty 中 的 保留 变量 Ssmarty now 或 者 Smarty 模板 中 的 日 期 `、、 | 左 “0 字符 段落 间距 
| %A, %B %e, %Y: date_format 函数 执行 格式 化 操作 时 使 用 的 格式 。 、、0 磅 ， 段 后 : 0 磅 
| 回 ”S$times: 当 传递 给 date_format 的 数据 为 空 时 ， 通 过 $times 设置 date_format 格式 化 的 默认 值 。 删除 的 内 容 : 这 个 
@date_format 函数 可 以 使 用 的 转换 格式 很 多 ， 其 常用 的 转换 格式 说 明 如 下 : + ---] 带 格式 的 : 代码 - 楷 ， 旨 
左 0 字符， 段落 间距 
0 磅 ， 段 后 : 0 磅 
删除 的 内 容 : - 
删除 的 内 容 : - 
删除 的 内 容 : - 
| 删除 的 内 容 : - 
| 1 
| 删除 的 内 容 : - 


第 章 ， 办 公 自动 化 系统 (PHPkymarti9[SSQC Somer2000:PDO 实现) 如 
6.4.5 “定义 左 侧 框架 内 显示 的 页 面 | 


的 形式 展示 问 里 办 公 自 动 化 系统 的 功能 。 在 leftphp 文件 中 ， 载 入 类 的 实例 化 文件 ， 查 询 | a 
出 问 易 办 公 自 动 化 系统 包含 的 功能 ， 并 且 将 查询 结果 赋 给 指定 的 模板 变量 ， 最 后 指定 模板 | 对 


,RTF 


代码 位 置 ， 配套 资源 mi\06\left.php | 
01 <?php | 


02 session startO; // 初 始 化 session 变量 | 

03 include("system/system inc php"): // 载 入 类 的 实例 化 文件 | 

04 $big list= "select* from tb_big list": // 定 义 查 询 数据 库 中 大 类 的 SQL 语句 

05 $big lists=$admindb->ExecSQL($big_list,Sconn); // 执 行 查询 语句 | 

06 $smarty->assign("t list",$big lists); // 将 查询 结果 赋 给 指定 的 模板 变量 | 

07 S$list="select* from tb list ": /定义 查询 数据 库 中 子 类 的 SQL 语句 | 

08 Slists=$admindb->ExecSQL(Slist.Sconn): Y! 执 行 查 询 语 ] -了 {删除 的 内 容 : 
09 $smarty->assign("t lists",$lists); // 将 查询 结果 赋 给 指定 的 模板 变量 | 

10 $smarty->display("left.html"): /指定 模板 页 | 

ri | 


在 left.html 模板 页 中 ， 应 用 Smarty 中 的 section 语句 ， 根 据 模板 变量 传递 的 数据 ， 完 | 
成 问 易 办 公 自 动 化 系统 中 功能 的 循环 和 输出， 并 且 定 义 onClick 事件 调用 change0 方 法 控制 | 


代码 位 置 : 配套 资源 ,mm06\systemvtemplates\lefthtml 


01 {section name=big list_ id loop=St_list} 

02 <div id="s{St_list[big list_ id].id}j" style="width:150px; padding-top:SpX: color:#FFFFFF: 
03 height:24px; background:url(images/jia.gif)" align="center" onclick= 

04 "javascript:change(e{St list[big list_id].id},s{St_list[big list_id].id})"> 

05 {Util text=$t list[big list id].f type}</div> 


06 <div id="e{$t_list[big_list_id].id}" style="display:none:"> | 
07 {section name=list_ id loop=$t_lists} | 
08 fifSt list[big_list_id].id 一 St_lists[list_id].f_ type id} | 
09 <div align="center" style="display: {Group text=$t_lists[list id].o group}"> | 


10 <ahref="{$t lists[list id].o url}?u id={$t lists[list id].id}" target="mainFrame"> 
下 {Util text=$t_lists[list_id].f_ name}</a></div> 


12 {/f 
13 {/section} 
14 </div> | 


15 {/section} ! 
在 leftjs 脚本 文件 中 ， 定 义 change(nu,Ix) 方 法 ， 控 制 <div> 标 签 的 显示 和 隐藏 ， 进 而 实 
代码 位 置 ， 配 套 资源 \mr\06\js\left.js 


01 function change(nu.lx){ | 
02 这 nu.style.display 一 "none"){ | 


。255 。 
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| 03 nu.style.display = "": 
| 04 Ix.style.background="url(images/jian .gif)": 
| 05 yelse{ 
| 06 nu.style.display = "none": 
| 07 Ix.style.background="url(images/jia. gif)": 
= 一 08 } 


ee 


6.4.6 ”定义 中 间 主 框架 显示 的 页 面 


| 主 框架 由 main.php、main.html 和 client_jsjs 三 个 文件 组 成 , 显示 问鼎 办 公 自动 化 系统 “| 删除 的 内 容 : js3 

| 中 的 企业 公告 、 活 动 安排 、 个 人 计划 和 审核 批示 的 最 新 内 容 。 在 main php 文件 中 ， 载 入 类 “、、| 删除 的 内 容 : 展示 
的 实例 化 文件 ， 从 不 同 的 数据 表 中 查询 出 企业 公告 、 活 动 安排 、 个 人 计划 和 审核 批示 的 最 十 删除 的 内 容 : 出 
新 数据 ， 并 且 将 查询 结果 赋 给 对 应 的 模板 变量 ， 最 后 指定 模板 页 ， 其 代码 如 下 : 


代码 位 置 ， 配套 资源 vmr0Gvmain.php 


01 <?php 

02 session startO: /初始 化 session 变量 

03 include("system/system.inc.php"); ~ /包含 数据 库 连 接 文件 
| 04 。 $sqlper = "select * from tb_person whereu id = 18":  // 查 询 人 事 部 发 布 的 企业 公告 数据 
| 05 S$per=$admindb->ExecSQL($sqlper,$conn): // 执 行 查 询 语句 
| 06 $smarty->assign("per",$per): // 赋 给 指定 的 模板 变量 
| 07 $sqlpers = "select * from tb_person whereu id= 19 ":  // 查 询 人 事 部 发 布 的 活动 安排 数据 
| 08 。 $pers=gadmindb->ExecSQL($sqlpers.Sconn): // 执 行 查询 语句 
| 09 $smarty->assign("pers",$pers); // 将 查询 结果 赋 给 指定 的 模板 变量 


10 S$p_sql="select*from tb plan wherep id=".$ SESSION['id]." order by id desc "; /计划 

11 S$psql=$admindb->ExecSQL($p_sql.$conn): 

12 $smarty->assign("psql",$psq)D); 

13 $sqllist="select* from tb list order by id desc "; // 查 询 功 能 类 别 

$list=$admindb->ExecSQL($sqllist. $conn): 

Lb $smarty->assign("list", $list); 

16 $a sql="select* from tb isswherep id=".$ SESSION['id]: // 查 询 审核 批示 的 数据 
17 $asql=$admindb->ExecSQL($a sql.$conn); 

| 18 $smarty->assign("asql".$asql): 

| 19 $smarty->display("main.html"); _ /指定 模板 页 

| 

| 


3 


20 > 
| 在 main.html 模板 页 中 ,根据 模板 变量 传递 的 数据 ， 应 用 section 语句 完成 各 类 数据 的 
| 循环 输出 ， 其 关键 代码 如 下 : 
| 代码 位 置 ， 配套 资源 \mr\06\system\templates\main.html 
01 {section name=psql id loop=$psql} 


02 {section name=list_id loop=$list} 
| 03 {if $psql[psql_id].p_type=—S$list[list_id].id} 
| 04 <tr> 
| 05 <td height="30" >{Util text=$psql[psql id].p_time} </td> 
| 06 <td>{Util text=$psql[psql id].p_planltruncate:10:"...":false} 


| 07 <ahref='show_plan.php?id={$psql[psql id].id}' target=' blank'> 查 看 全 文 </a></td> 
区 “256 . 
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08 <td width="50" align="center" valign="middle"> {Uiil text=$list[list id] f name} </td> | 


09 </t> | 

10 {if | 

11 {/section} | 

12 {/section} | 区 
13 {Srstl page} | 晤 | 


6.5 人 事 消息 模块 设计 
| 
人 事 消息 模块 主要 是 对 文件 进行 收发 管理 ， 模 块 的 设计 和 实现 并 不 十 分 复杂 ， 人 | “人 届 除 的 内 容 : 的 
| “型 除 的 内 容 : 是 
员 的 意见 想法 首先 都 是 在 这 里 体现 出 来 的 。 | “删除 的 内 容 : 位 置 


1 
6.5.1 人 事 消息 模块 概述 
! 
Ee i | 六 A 
人 事 消 息 模块 主要 包含 了 两 部 分 内 容 。 一 部 分 是 面向 全 体 用 户 的 ， 包 括 查 看 公告 、 活 _| -| 删除 的 内 容 : ， 


动 、 意 见 箱 等 ; 另 一 部 分 仅 对 人 事 部 开放 ， 其 他 用 户 不 允许 、 也 不 会 看 到 的 页 面 ， 如 公告 | - -二 删除 的 内 容 : 是 


管理 、 意 见 管理 等 。 人 事 消 息 模 块 的 框架 如 图 6.13 所 示 。 一 二 删除 的 内 容 : 下 面 给 出 


1 1 
nD) 
超级 用 户 1 1 车 通用 户 


图 6.13 _ 人 事 消息 模块 功能 结构 图 | 
6.5.2 $_GET0 和 $_POST0 全 局 数组 


在 人 事 消息 模块 中 ,企业 公告 和 活动 安排 由 p_message.php 和 p_message.html 两 个 文件 组 | 

成 。 其 中 ， 通 过 p_message.php 获取 动态 PHP 数据 ， 根 据 超 链接 传递 的 参数 值 进行 判断 ， | 删除 的 内 容 : 级 

而 在 p_message.html 模板 页 中 输出 不 同 的 内 容 。 在 P_messagephp 中 ， 为 了 区 分 不 同 的 操作 ， 

需要 给 P_message php 传 一 个 u_id 值 ， 在 数据 表 中 根据 不 同 的 u_id 值 ， 取 得 不 同类 别 的 内 容 。 | 
传 值 方式 有 url 传 值 方式 (如 p_message.php?u id=1 ) 和 表单 传 值 方 式 两 种 。 同 样 ， 
在 接收 页 中 ， 接 收 方式 也 有 两 种 : get 方式 和 post 方式 。PHP 中 使 用 预定 义 变 量 $_GET[] 
和 $_POSTU 来 接收 传 值 ， 格 式 为 : | 
“257 。 本 
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| $ GETPOST[u id]:; /和 注意， 变量 名 都 为 大 写 < -- 1] 带 格式 的 : 程序 ， 缩 进 
| 侧 : 0 厘米 ， 首 行 FE 
”对 于 un 传 值 方式 ， 接 收 页 始终 用 $_GET[ 变 量 来 接收 ， 如 果 使 用 form 表单 传 值 ， 那 [27 厘米， 图案: 演 
| 么 就 看 form 表单 中 method 属性 的 设置 。 如 果 method=get， 就 使 用 $_GET[D] 变 量 ; 如 果 
上 | method=post， 就 使 用 $_POST[] 变 量 。 
2 | PHP 对 传 值 方式 和 接收 方式 的 规定 很 严格 ， 用 $_POST[m id] 接 收 不 到 

P_message.php?u id=1 传 过 来 的 参数 。 同 样 ,用 $_GET[u_ id] 也 接收 不 到 method=post 的 表 
单元 素 值 。 但 是 , 吕 REQUEST 全 局 数组 可 以 获取 get 方 法 、post 方 法 和 http Cookie 传递 -| 删除 的 内 容 : 有 一 个 


到 脚本 的 信息 。 如 果 在 编写 程序 时 ， 不 能 确定 通过 什么 方法 提交 数据 ， 就 可 以 通过 “、、-( 删除 的 内 容 : 


”$_REQUEST] 全 局 数组 获取 提交 到 当前 页 面 的 数据 。 下 、、[ 列 除 的 内 容 : ， 
| 
ee 和 和 和 和 几 人 狼 | 删除 的 内 容 :中 
注意 : AN 

| 如 果 在 php.ini 配置 文件 中 GLOBAL=OMN/OFF 的 值 为 ON， 那么 直接 写 $name 就 可 以 


出 除 的 内 容 : 是 
| 调用 表单 元 素 的 值 ， 而 不 区 分 get 和 post; 如 果 为 OEE， 则 不 可 以 。 直 接应 用 表单 名 称 十 、、 \ 小 删除 的 内 容 : 的 


分 方便 ， 但 也 存在 着 安全 隐患 ， 推 荐 关闭 GLOBAL 。 WR 
| 、、 | 型 除 的 内 容 : 这 行 

| Ye 
| 6.5.3 ”消息 管理 的 实现 过 程 删除 的 内 容 : 。 

| 


删除 的 内 容 : ” 
必 \ 删除 的 内 容 :“ 
人 删除 的 内 容 : ” 
\[ 删除 的 内 容 :“ 
[删除 的 内 容 :” 


6.14 消息 管理 页 面 运行 结果 


| 消息 管理 的 主 文件 由 p_manage.php 和 p_manage.html 组 成 ,在 动态 页 p_manage.php 中 ， 
| 首先 设置 页 面 的 编码 格式 ， 然 后 权限 检查 文件 (checphp) 判断 用 户 是 否 为 登录 用 户 、 是 否 
| 为 非法 链接 。 如 果 被 系统 判断 为 非法 操作 ， 系 统 将 直接 关闭 ; 如 果 没有 异常 情况 ， 系 统 才 继 


模板 的 配置 。 调 用 数据 库 管 理 类 中 的 ExecSQL0O 方 法 ， 查 询 tb_person 表 中 的 数据 ， 最 终 将 
查询 结果 赋 给 模板 变量 ， 并 且 指定 模板 页 rsxx/p_manage.html， 在 模板 页 输出 查询 结果 。 其 
关键 代码 如 下 : 
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代码 位 置 : 配套 资源 \mr\06\p_manage.php | 


01 <?php 

02 header ("Content-type: text/html: charset=utf-8" ): /设置 文件 编码 格式 

03 include "inc/chec.php": /包含 权限 文件 | # 
04 include("system/system.inc.php"): // 包 含 类 的 实例 化 文件 | 全 一 


05 $sqlstr = "select id.p_time.p_title from tb person": /定义 SQL 语句 


06 Sres-Sadmindb->ExecSQL(Ssqlstr,Sconn); 执行 SQL 语 旬 | x 删除 的 内 容 : 
07 | 


Ssmarty->assign("res" Sres): // 将 查询 结果 赋 给 模板 变量 | 
08 Ssmarty->display("rsxx/p_manage.html"): 二 页 | -项 除 的 内 容 : 
?> | 


| 

在 模板 页 P_ manage .html 中 ， 通 过 Smarty 模板 中 的 section 语句 循环 输出 模板 变量 中 | 
传递 的 数据 ， 并 且 设 置 添加 、 修改 和 删除 消息 的 超 链接 ， 链 接 到 对 应 的 文件 完成 数据 的 操 站 --- 删除 的 内 容 : 级 

作 。 其 关键 代码 如 下 : | 


| 
代码 位 置 ， 配套 资源 \mr\06\system\templates\rsxx\p_manage.html | 


| 
01 {section name=res_id loop=$res} | 


02 <t> | 
03 <td align="center" valign="middle" scope="col"> {Util text=$res[res_id].p_time}</td> | 
04 <td height="25" align="center”valign="middle” scope="col">{Util text=$res[res id]. | 
p title}</td> | 
05 <td width="150" height="25" align="center" valign="middle" scope="col"> 
06 <a href='m_message.php?id={$res[res_id].id}> 修 改 </a>/ | 
07 <a href='d_message chk.php?id={S$res[res id].id}' onclick='return del_ messO;> 删 除 </a> | 
08 </td> | 
09 </t> | 
10 {/section} | 
11 <tw> | 
12 <td height="30" align="right" valign="middle" colspan="3"> | 
13 <a hre 人 add manage.php' target="mainFrame"> 发 布 新 消息 </a></td> | 
14 </> | 
一 -| 删除 的 内 容 :“ 
_(1D 发 布 新 六 \、、| 删除 的 内 容 : ” 
单 击 “ 发 布 新 消息 ” 超 链接 , 将 进入 发 布 消息 页 1 了 [ 莉 除 的 内 容 :“ 
a NA 一 
所 示 。 NS 删除 的 内 容 : ” 
| AN 开除 的 内 容 :“ 
| \\ 删除 的 内 容 : ” 
| [ 草 咎 式 的 : 正文 顷 进 
| 六 东 业 这 的 :下 厘米 ， 
| ek 0 磅 ， 段 
! i 
| 删除 的 内 容 : . 
| 


6.15 发布 消 息 页 面 运 行 结果 
“259° 
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| 发 布 新 消息 页 面 由 add_manage.html、add_manage.php 和 add_manage_chk.php 3 个 文 ““- -六 删除 的 内 容 : 三 
| 件 组 成 。 其 中 ， 在 add_managephp 文件 中 判断 用 户 的 权限 ， 指 定 模 板 页 ; 在 模板 页 
”add_manage.html 中 创建 表单 元 素 ， 完 成 消息 的 提交 ， 其 部 分 表单 元 素 如 表 6.9 所 示 。 


全 表 6.9 ”发布 消息 页 面 的 主要 表单 元 素 
| 名 称 | 元 素 类 型 重要 属性 含 义 
addmess form | action="add manage chk.php" method="post" id="addmess" | 发 布 消息 表单 
| _Putite text | name="p title" id="p _title” | 消息 标题 
| Content textarea name="p_content" id="p_content" cols="60" rows="15" 消息 内 容 


| <option value="9"> 企 业 公告 </option> 、 
| p_type select Fie ee . 消息 类 型 
<option value="10"> 活 动 安排 </option> 


submit2 submit value=" 发 布 " onclick="return add messO:" “发 布 ”按钮 


| 码 如 下 : 
| 代码 位 置 : 配套 资源 \mr\06\add_manage_chk.php 
| 
| 01 <?php 
| 02 。 header ("Content-type: texthtml: charset=utf-8" ): /设置 文件 编码 格式 
| 03 include "inc/chec.php"; // 判 断 用 户 权限 
04 include("system/systeninc.php"); // 包 含 类 的 实例 化 文件 
| 05 。 ”if\isset($_POST['p_title]) && isset($_POST['p_content]){ /判断 提 交 数 据 是 于 为 真 
| 06 $dates=date("Y-m-d H:i:s"): // 定 义 时 间 
| 07 $sqlstr = "insert into tb_person(p_title,p_content,p_time,u id) 


08 values(".iconv("utf-8","gbk",S POSTI['p 


09 miconv("ntf-8","gbk"$ POST[p_content])."".$dates."".$_POST['p type].")":// 定 义 添加 


语句 
| 10 Sresult=$admindb->ExecSQL($sqlstrSconn): /执行 添加 语句 
| 1 if($result) 
| 12 echo "<script>alert(' 操 作成 功 ! ):window.location href='p_manage.php';</script>"; 
| 13 else 
| 14 echo "<script>alert(' 系 统 繁忙 ， 请 稍 后 再 试 '):history.go(-1):</script>"; 
| 15 j}else{ 
| 16 echo "<scripf>alert( 添加 内 容 不 能 为 空 ! )):windowlocation href-'add_ manage. 
| php':</script>": 
| Tn 
| 18 Ye 
-1 删除 的 内 容 
th SP A 带 格式 的 : 正文 ， 缩 进 


行 缩 进 : ”0.74 厘米 
消息 发 布 后 ， 可 以 随时 对 消息 内 容 进 行 修改 。 在 消息 管理 页 面 中 ， 选 择 要 修改 的 消息 


列 ， 单 击 “ 修 改 ” 超 链接 将 进入 消息 修改 页 面 。 消 息 修改 页 面 由 m_message.php、 


m_message.html 和 m_message_chkphp_3 个 文件 组 成 。 其 中 ， 在 m_message.php 文件 中 根 __- -| 删除 的 内 容 : 三 
| 据 超 链接 传递 的 ID 值 查询 出 指定 的 数据 ， 并 且 将 查询 结果 赋 给 模板 变量 ， 指 定 在 模板 页 _- - - -| 删除 的 内 容 : 级 


第 @ 章 办 公 自 动 化 系统 (PHP+SmaripiM5SQLSerer2000:PDO 实 搞 ) 用 


m_message.html 中 通过 表单 元 素 输出 查询 结果 。 其 关键 代码 如 下 : 
代码 位 置 : 配套 资源 \mr\06\m_message.php 


01 
02 
03 


<?php 

header ( "Content-type: text/html: charset=utf-8" ): // 设 置 文件 编码 格式 
include "inc/chec.php": /判断 用 户 权限 
include(™ ne php"): // 包 含 类 的 实例 化 文件 


Sres=$admindb->ExecSQL($sqlstr,Sconn); zd 执行 查询 
Ssmarty->assign("res", Sres); // 将 查询 结果 赋 给 模板 变量 
$smarty->display("rsxx/m _message.html"); 指定 模板 页 ~- 
> 


在 模板 页 m_message.html 中 ， 创 建 表单 ， 将 模板 变量 传递 的 数据 在 表单 元 素 中 输出 ， 
指定 数据 的 修改 页 为 m_message_chkphp。 消 息 修改 页 面 中 的 表单 元 素 如 表 6.10 所 示 。 


表 6.10 修改 页 面 的 表单 元 素 


各 称 重要 属性 含 义 
addmess action="m message_chk.php" method="post" 修改 消息 表单 
p title | text | value=" {Util text=$res[res id].p_title}" 消息 标题 
p_content | tien | Util text=$res[res id].p_content 消息 内 容 


{if $res[res_id].u id—18}} 
<option value="18" selected="selected"> 企 业 公告 </option> 
<option value="19"> 活 动 安排 </option> 
{else} 消息 类 型 
<option value="18"> 企 业 公告 </option> 
<option value="19" selected="selected"> 活 动 安排 <Joption> 
Ss 
| somit | 


-删除 的 内 容 : 级 


| 


| (RR 


id value=" {Sres[res_id].id}" 修改 消息 ID | 

submit2 Value=" 修 改 " onclick="return add messO:" “修改 ”按钮 | 
消息 修改 完成 后 ， 单 击 “ 修 改 ” 按 钮 将 会 在 m_message_chk.php 页 中 处 理 修改 事件 ， s -| 删除 的 内 容 : 将 会 

re 过 来 的 ID 定位 到 要 修改 的 消息 项 ， 使 用 update 语句 实现 对 数据 的 更 新 。 | 
关键 人 iT， | -了 {删除 的 内 容 : 程序 

代码 位 置 ， 配套 资源 \mi\06m_message_chk.php | 

01 <2php | 

02 header ( "Content-type: text/html: charset=utf-8" ): /设置 文件 编码 格式 | 

03 include "inc/chec.php": | 

04 include("system/system.inc.php"): | 

05 $dates=date("Y-m-d H:i:s"): | 

06 $sqlstr = "update tb_person set p_title = "".iconv("utf-8","gbk",$ POST[p_title]). | 

07 ™p_content = "".iconv("utf-8","gbk",$ POSTI['p_content])."",p_time = "".Sdates.""', | 

08 uid=".$ POST[p_type]." whereid="S_ POST['id]; | 

09 Sres=$Sadmindb->ExecSQL(S$sqlstr,Sconn); 


“ls 
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| 10 if(sres) 
| 11 echo "<script>alert( 操 作成 功 ! "):window.location.hre 仁 'p_manage.php':</script>":; 
| 12 else 
| 13 echo "<script>alert( 系 统 繁忙 ， 请 稍 后 再 试 '):history.go(-1):</script>"; 
14 ?> 
。 [删除 的 内 容 : . 
其 除 消息 -sanaeaaarEaaoELa1E ~ 十 带 格式 的 : 正文 ， 缩 进 


行 缩 进 : ”0.74 厘米 


DAT 


图 6.16 ”删除 操作 的 运行 结果 图 


删除 消息 时 ， 选 择 要 删除 的 消息 列 ， 单 击 “ 删 除 ” 超 链接 ， 弹 出 确认 删除 对 话 框 ， 单 
击 “ 确 定 ” 按 钮 将 要 删除 消息 的 ID 号 传 给 系统 ， 通 过 消息 处 理 函 数 将 消息 删除 。 关 键 代 
码 如 下 : 

代码 位 置 ， 配套 资源 mi\06\d_message_chk.php 


01 <?php 

| 02 header ( "Content-type: text/html; charset=utf-8" 
03 include "inc/chec.php"; 

04 include("system/system.inc.php"); 

05 Ssqlstr = "delete from tb_person where id = ".$S_GET[T'id']; 
06 Sres=$admindb->ExecSQL($sqlstr,Sconn); 


// 设 置 文 件 编码 格式 


) 


07 if(gres) 

08 echo "<script>alert( 操 作成 功 ! "):window.location.hre 人 ='p_manage.php':</script>"; 
09 else 

10 echo "<script>alert(' 系 统 繁忙 ， 请 稍 后 再 试 "):history.go(-1):</script>"; 

11 > 


6.6 考勤 管理 模块 设计 


考勤 管理 模块 是 问 是 办 公 自 动 化 系统 中 每 天 都 要 使 用 的 功能 模块 之 一， 也 是 比较 重要 _- -人 删除 的 内 容 : 功能 
的 模块 之 一 。 除 了 包括 正常 的 上 下 班 登记 功能 外 ， 还 要 包括 病 事假 登记 和 加 班 登记 等 特殊 。 二 删 除 的 内 容 : 到 
| 登记 功能 。 管 理 员 通过 考勤 记录 实现 对 上 下 班 及 加 班 标准 时 间 的 设置 。 


| 
| 
| 
” 。262 。 
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和 | 


6.6.1 考勤 管理 模块 概述 


考勤 管理 模块 的 主要 功能 有 | 
回 上 下 班 登记 : 包括 上 班 登记 和 下 班 登记 。 | 会 内 
回 病 事假 登记 : 包括 病假 登记 和 事假 登记 。 | ~ 
回 加 班 登记 : 包括 加 班 上 班 登记 和 加 班 下 班 登记 。 ote 
回 考勤 记录 : 包括 上 下 班 标准 时 间 设 置 和 加 班 标准 时 间 设 置 。 | 
考勤 管理 模块 的 功能 结构 如 图 6.17 所 示 。 | 


加 班 上 班 登记 


(加 班 下 班 登记 ) | 


图 6.17 考勤 管理 模块 功能 结构 图 
6.6.2 ”Smarty 模板 中 并 语句 散 套 技术 


根据 u_id 来 判断 是 哪 种 功能 类 型 ,参数 过 的 值 ， 分 3 种 情况 ， 上 下 班 登记 、 

病 事假 登记 和 加 班 登 记 。 : 
判断 登记 类 型 ， 一 共 分 6 种 情况 ， 上 班 、 下 班 、 病 假 、 事 假 、 加 班 签到 和 加 班 签 退 。 | 
判断 状态 类 型 ， 一 共 分 10 种 情况 : 上 班 迟到 、 上 班 早 退 、 正 点 上 班 、 正 点 下 班 、| 


办 轨 


。263 。 要 


] 


代码 位 置 ， 配套 资源 umrm06\kqgImessage_note.html 加 删除 的 内 容 : 。 


01 {section name=rec id loop=$rec} 

02 <tr> 

03 <td height="25" align="center" valign="middle">{Util text=$rec [rec id]. 
rdate}</td> 

04 <td height="25" align="center" valign="middle">{Util text=$rec [rec id]. 
T time}</td> 

05 <td height="25" align="center" valign="middle"> 

06 {section name=uc_ id loop=$uc} 

07 {if $rec[rec id].p id 一 Suc[uc id].id} 

08 {Util text=$uc[uc id].u_name} 

09 {/if} 

10 {/section} 

11 <td> 

12 <td align="center" valign="middle"> 

13 {if $rec[rec id].r type—1 } 

14 {if $rec[rec id].r state=—=0 } 

15 正点 上 班 

16 {else} 

17 迟到 

18 {ff 

19 {else} 

20 三 

21 {i 

22 <td> 

23 <td align="center" valign="middle"> 

24 {if $rec[rec id].r type 一 0 } 

25 {if $rec[rec_id].r_state—0 } 

26 退 

27 {else} 

28 正点 上 班 

29 {/if} 

30 {else} 

31 - 

32 {f/f 

33 <td> 

34 </tr> 

35 {/section} 

Smarty 模板 中 让 语句 的 应 用 与 PHP 中 类 似 ， 叭 一 区 别 是 必须 以 f/ 夫 标记 结束 。。。。。__ -开除 的 内 容 :非常 


6.6.3 ”上 下 班 登 记 的 实现 过 程 
单 击 “ 考 勤 管理 ”(“ 上 下 班 登 记 ” 超 链接 ， 可 在 主 显示 区 (mainFrame》 内 显示 个 人 -删除 的 内 容 : 菜单 中 的 
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上 下 班 的 登记 记录 和 上 下 班 登记 链接 ， 用 户 可 以 在 这 里 进行 登记 和 查找 。 上 下 班 登记 页 面 | 
的 运行 结果 如 图 6.18 所 示 。 | 


自动 化 管理 系统 


6.18 上 下 班 登记 的 运行 结果 


在 上 下 班 登记 中 ， 通 过 登录 用 户 ID， 从 数据 表 tb_register 中 返回 用 户 的 登记 记录 集 ， 
并 显示 在 页 面 中 。 首 先 ， 在 work_note php 文件 中 根据 超 链接 传递 的 


2 ID， 出 定 | -- 删除 的 内 容 : 级 
用 户 的 登记 信息 ， 并 且 将 查询 结果 赋 给 模板 页 work_note.html 其 关键 代码 如 FF: _ -一 删除 的 内 容 : 。 


代码 位 置 ， 配 套 资源 \mr\06\message_note.php | 


01 <?php 
02 ”header ("Content-type: text/html; charset=utf-8" ); /设置 文件 编码 格式 
03 include("inc/chec.php"): | 
04 include("systemy/system.inc.php7: 
05 $sqlstrl = "selectf name from tb list where id=".$ GET[m id]: 
06 Srecord1=$admindb->ExecSQL($sqlstr1.$conn): 
07 $smarty->assign("f name",$record1[0]['f_ name']): 
08 $smarty->assign("u id".$ GET[u id]): 
09 Ssqlstr = "select id,r_date,r time,r_ type,r_state,r_remark from tb_register 
10 ”wherer id="S GET[ id']." and p_id=".$ SESSION['id']." order by id desc"; 
11 S$rec=$admindb->ExecSQL($sqlstr,$conn): 
12 S$smarty->assign("rec". $rec): 
13 $smarty->display("kqgl/work note.html"): 
> 


14 
然后 ， 在 模板 页 work_note.html 中 循环 输出 查询 结果 ， 并 且 通 过 站 语句 对 用 户 登记 类 | 
型 和 登记 状态 进行 判断 ， 输 出 判断 结果 ， 其 关键 代码 和 FT: | {于 的 内 容 :， 


代码 位 置 ， 配套 资源 \mr\06\kqgl\work_note.html 
ol {fsu id—23} 


02 上 下 班 登 记 | 
03 {elseif $u_id—24} | 
04 病 事假 登记 | 
05 {elseif Su id—25} 

06 加 班 登 记 | 
07 { 刘 | 
08 {section name=rec id loop=$rec} | 
09 <t> | 
10 <td height="25" align="center" valign="middle">{fUtil text=$rec[rec id]. r_date} 


</td> 


。265 。 .< 


Bi 项 目 业 例 分 析 


11 <td height="25" align="center" valign="middle">{Util text=$rec[rec id]r time} 
| <itd> 
| 12 <td height="25" align="center' valign="middle"> 

13 {1f $rec[rec id].r type 一 0} 

14 下 班 


| 
| 
侠 ) | 15 {elseif $rec[rec id]r type—1} 

| 16 上 班 

x {elseif $rec[rec_id].r_ type 一 2} 
| 18 加 班 签到 
| 19 {elseif Srec[rec id].r type—3} 
| 20 加 班 签 退 
| 21 {elseif Srec[rec id]r type—4} 
| 病假 
| 
| 
| 
‖ 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
) 


23 {elseif $rec[rec id].r_ type—5} 
事假 


25 {if} 
26 <td> 
27 <td height="25" align="center" valign="middle"> 
28 ff $rec[rec id].r_ type—0} 
29 {if $rec[rec_id].r_state—0} 

退 


31 {else} 

32 正点 下 班 

33 {/f} 

34 {elseif $rec[rec_id].r_ type—1} 
35 {if $rec[rec_id].r_state—0} 


37 {else} 

38 迟到 

39 {/if} 

40 {elseif $rec[rec id].r type—2} 
41 {if $rec[rec_id].r_state—0} 
42 正点 加 班 

43 {else} 

44 晚点 加 班 

45 {/f} 

46 {elseif $rec[rec_id].r_type—3} 
47 {if $rec[rec id].r state 一 0} 
48 早退 


52 {elseif Srec[rec id].r type—4} 
53 {if $rec[rec_id].r_state—0} 
病假 


55 {else} 


57 {/ 诈 
58 /if 
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59 </td> | 

60 <td height="25" align="center”" valign="middle"> | 

61 {if $rec[rec id].r remark!=null} | 

62 {Util text=$rec[rec_ id].r remark} | 

63 else | # 
> {else} | 伟 门 
65 {ff | 

66 <ltd> Note 
67 </> | 

68 {/section} | 

当 单 击 “ 上 下 班 登记 ” 超 链接 时 ， 就 会 弹出 登记 页 面 ， 用 于 进行 上 下 班 的 记 操 作 ，_ | 删除 的 内 容 : 户 就 可 以 


在 “登记 类 型 ”下 拉 列 表 框 中 选择 登记 类 型 ， 如 果 有 人 迟到 或 早退 等 特殊 情况 ， 需 要 在 “ 备 
注 ”列表 框 中 说 明 原 因 ， 最 后 单 击 “ 登 记 ” 按 钮 进行 登记 ， 如 果 登 记 成 功 ， 将 显示 提示 对 
话 框 。 登 记 页 面 的 运行 结果 如 图 6.19 所 示 。 


2.168.159/TM/13/p lcginphpir d=3 


姓名 : 1001 
登记 类 型 : | 上 于 [] 
EE3:E] 
和 


[EE] 


[后 @ Intemet | 保护 要 式 : 要 用 


图 6.19 上 下 班 登 记 页 面 的 运行 结果 及 提示 对 话 框 
在 登记 模板 页 P_ login html 中 , 主要 有 3 个 表单 元 素 和 1 个 隐藏 表单 , 如 表 6.11 所 示 。 | 
表 6.11 上 下 班 登记 的 表单 元 素 | 


名 称 | 元素 类 型 | 重要 属性 | 名 & 义 | 
Pl form ei 登记 表单 | 
uname | text 登记 人 | 
{if $uc—23} | 

<option value="1"> 上 班 </option> | 

<option value="0"> 下 班 </option> | 

{elseif Suc 一 24} | 

<option value="4"> 病 假 </option> 、 | 

Wtype select is Wai 5 心事 机 5opE6 登记 类 型 | 
{elseif Suc 一 25} | 

<option value="2"> 加 班 签到 </option> | 

<option value="3"> 加 班 签 退 </option> | 

| 

T_Temark textarea name="r remark" rows="5" 备注 | 
rid hidden value="{$uc}" 功能 ID | 
Submit2 submit Value=" 回 复 " onclick="return re backO:” “登记 ”按钮 | 
| 

\ 


“20s 


01 
02 
03 
04 
05 


23 


| 执行 insert 语句 ， 添 加 新 记录 ,关键 人 mtF: 的 
代码 位 置 ， 配套 资源 \mr\06\p_login_chk.php ”| 删除 的 内 容 : 程序 


<?php 
header ( "Content-type: text/html: charset=utf-8" ): /设置 文件 编码 格式 
include("inc/chec.php"): 
include("system/system.inc.php"); 
/1 迟到 
/0 正点 
// 取 出 正点 上 班 时 间 
// 根 据 u_type 判断 上 、 下 、 加 班 
iftisset($_POST[T id])){ 
if($ POST[Tr id] == "23" or $ POST[r id] =—= "25" ){ 
这 $_ POST[m type]—0) 
$t_ sql = "select* from tb_setup where id= 2"; 
else 这 $ POST[m type] =—= 1) 
$t_ sql = "select * from tb_setup where id = 1"; 
else 这 $ POST[m type] 一 2) 
$t_sql = "select * from tb_setup where id = 3"; 
else 这 $ POST[m type] 一 3) 
$t sql = "select* from tb setup where id = 4": 
S$rec-Sadmindb->ExecSQL(St sqLSconn); 
$s time = Srec[0][1 time']: 
© Snow_time = date("h:i:s"); // 当 前 登记 时 间 
四 $l sql= "insert into tb register (r date,r time,r type,r state,r remark,r idp id) 
values(".date("Y-m-d").",".date("H:i:s").™,".$ POST[u type].",".((strtotime($now time)- strtotime 


($s_time) > 0)71:0)", 


miconv("utf-8","gbk",$ POST[T remark'"]).".".$ POST['r id].".".$ SESSION[id].")": 
jelseifs_ POST[r id] = "24"){ 
$1_sql = "insert into tb_register (1_date,r time.r type.r_state,r remark.r id,p id) 
values(".date("Y-m-d").".".date("H:i:s").".".$_POST['u type].".3", 
miconv("utf-8"."gbk",$_POST['r remark])""S POST['r id].".".$_SESSION['id].")": 
}else{ 
echo "<script>alert( 错 误 '):history.go(-1):</script>"; 


} 
Sl rst=$admindb->ExecSQL(SI sql,Sconn); 
if(SL rs){ 
echo "<script>alert(' 登 记 完成 ):window.closeO:</script>": 
}else{ 
echo "<script>alert( 错 误 '):history.go(-1);</script>"; 
. 
} 
pe 
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< 关键 代码 解析 


v 2 > A 
@ ((strtotime($now_time) - strtotime($s_time) > 0)?1:0): 根据 以 上 内 容 得 到 的 SQL 语句 ,其 中 strtotime0 
析 为 一 个 unix 时 间 蕉 ,如 strtotime("2007-07-11 
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6.6.4 设置 时 间 的 实现 过 程 


考勤 记录 页 面 主要 有 西 个 功能 。_ 一 是 显示 所 有 员工 的 考勤 信息 。 二 是 设置 标准 时 间 。 
显示 所 有 员工 的 考勤 信息 的 实现 过 程 和 6.6.3 节 中 的 实现 方式 类 
全 体 职员 ， 只 要 略微 改动 SQL 语句 即 可 。 


进入 设置 时 间 页 面 ， 设 置 时 间 页 面 的 运行 结果 如 图 6.20 所 示 。 


| +。 THER | ES 到 | jiR 
[gE |r:10:00 [Ea le:00:00 | 
| | Ww | Wi | Wy 


图 6.20 设置 时 间 页 面 的 运行 结果 


代码 位 置 ， 配套 资源 \mr\06\set.time.php 


01 
02 


然后 ， 在 模板 页 set_time.html 中 ， 设 置 表单 ， 添 加 表单 元 素 输出 系统 设置 的 时 间 ， 并 


<2p 

header ("Content-type: text/html; charset=utf-8" ); /设置 文件 编码 格式 
include("system/system.inc.php"); 

$sqlstr = "select * from tb_setup": 
Srec=$admindb->ExecSQL($sqlstr. $conn): 
$smarty->assign("rec". $rec): 

$smarty->display("kqgl/set time.html"); 

> 


代码 位 置 ， 配 套 资源 \mi\06\kqgl\set.time.html 


<form name="forml" method="post" action="set time chkphp"> 
<table border="0" cellspacing="0" cellpaddine="0" background="images/bg.jpg"> 
<tr> 
<td width="150" height="25" align="center" valign="middle"> 上 班 签到 </td> 
<td width="150" height="25" align="center" valign="middle"> 下 班 签 退 </td> 


“4 


{删除 的 内 容 : 代码 贴 十 : 
| 删除 的 内 容 : 。 
由 删除 的 内 容 :等 。 
| 删除 的 内 容 : 作用 是 
删除 的 内 容 : 就 


二 删除 的 内 容 : 的 
十 删除 的 内 容 : 主要 有 两 
删除 的 内 容 : ， 
人 而 除 的 内 容 : 相 


多 删除 的 内 容 : 就 


删除 的 内 容 :“ 
人 
删除 的 内 容 : ” 


二 删除 的 内 容 : ， 


“删除 的 内 容 : 。 
-六 删除 的 内 容 :“ 


、、 [删除 的 内 容 : " 
ee 
NS 出 除 的 内 容 :“ 
上册 除 的 内 容 : ” 


| AN 删除 的 内 容 :“ 


人 删除 的 内 容 :” 
[出 除 的 内 容 :“ 
[出 除 的 内 容 : ” 
[出 除 的 内 容 : 。 


-| 删除 的 内 容 : 。 


人 ie 项目 业 全 分析 


| 06 <td width="150" height="25" align="center" valign="middle"> 加 班 签到 </td> 
| 07 <td width="150" height="25" align="center" valign="middle"> 加 班 签 退 </td> 
| 08 < 
| 09 <t> 
| 10 {section name=rec_id loop=S$rec} 

1 <td height="30" align="center" valign="middle"> 

| <input type="text"” name="] timefS$rec[rec id].id}" value="{$rec[rec id].] time}" 
| size=15></td> 
| 13 {/section} 
| 14 </t> 
| 15 <t> 
| 16 <td height="30" align="center" valign="middle"><input type="submit" name="u logo" 
，value=" 设 置 "></td> 
| 17 <td height="30" align="center" valign="middle"><input type="submit" name="d logo" 
”value=" 设 置 "></td> 
| 18 <td height="30" align="center" valign="middle"><input type="submit" name="a logo" 
”value=" 设 置 "></td> 
| 19 <td height="30" align="center" valign="middle"><input type="submit" name="q logo" 
value=" 设 置 "></td> 
| 20 </tr> 
| 21 </table> 


| 4 </form> 


最 后 ， 创 建 set_time_chk php 文件 ， 获 取 表单 中 提交 的 数据 ， 完 成 时 间 的 更 新 操作 ， -删除 的 内 容 : 。 
其 关键 代码 如 下 


| 代码 位 置 ， 配套 资源 mr\06@\set.time_chk.php 


| 01 <?php 

| 02 header ( "Content-type: text/html: charset=utf-8" ): /设置 文件 编码 格式 
| 03 include("inc/chec.php"): 

| 04 include("system/system.inc.php"): 

| 05 iflisset($_POST['u logo])){ 
| 


06 $sqlstr = "update tb setup set 1 time =".$ POST[1 timel’']." where id=1"; 
07 }else ifisset($_ POST['d logo])){ 
08 $sqlstr = "update tb_setup set | time =".$_ POST['1 time2']." where id=2"; 
| 09 jelseifisset($_POST['a logo])){ 
| 10 $sqlstr = "update tb_setup set | time =".$ POST[1 time3']." where id=3"; 
| 11 yelseiftisset($ POST['q logo]){ 
12 $sqlstr = "update tb_setup set | time =".$ POST[1 time4']." where id=4"; 
| 13 }else{ 
| 14 echo "<script>alert(' 非 法 登录 '):window.closeO0:</script>"; 
| i 


| 16 Sresult=$admindb->ExecSQL(Ssqlstr,Sconn); 
| 17 if$result) 


| 18 echo "<script>alert(' 设 置 成 功 ):window.closeO:</script>": 
| 9 “chs 

| 20 echo "<script>alert(' 设 置 失败 ):window.closeO:</script>": 
| 21 i> 
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6.7 后 台 主 页 设计 | 


6.7.1 后 台 主 页 概述 


如 果 说 前 台 是 系统 的 外 衣 ， 那 么 后 全 就 是 系统 的 灵魂 。 数 据 更 新 、 系 统 升级 ， 其 至 是 | 
安全 隐患 ， 都 源 于 后 台 的 设计 是 否 完善 ， 功 能 是 否 强大 。 可 以 说 ， 后 台 越 完美 ， 系 统 拥有 | 
的 “外 衣 ” 才 会 越 华丽 ， 人 们 的 目光 才 会 被 吸引 。 


Eo 
Ra 
bo 
亚 
总 
EE 
浇 
痘 
到 
迅 
俏 
此 
本 
此 
烟 
[ey 
Ee 
| 


左 侧 导航 栏 : 包括 各 个 管理 模块 及 分 类 。 | 


|“*% 


部 门 管理 模块 : 主要 用 于 对 部 门 信息 的 操作 ， 包 括 添加 、 修 改 、 删 除 和 查看 功能 。 | 


加 加 网 加 


职员 管理 模块 : 主要 用 于 对 职员 信息 的 统一 管理 ， 包 括 添加 、 修 改 、 删 除 和 查找 | 
职员 。 | 
回 权限 管理 模块 : 主要 用 于 对 部 门 、 职 员 和 用 户 组 的 功能 权限 分 配 。 | 
回 ”系统 管理 模块 : 维护 系统 日 志和 修改 管理 员 密码 。 


所 示 。 <- 


加 


| as | 电话 .| 

mn | em | ss em | 
| corem | Aws Naas | | 
[ 区 到 | I zz | 
| | | me Jem | | 
En 


| ne pe | 
| 
主 县 未 区 


图 6.21 问鼎 办 公 自 动 化 系统 后 台 主 页 
6.7.2 ”后台 主页 框架 技术 | 
后 台 页 面 和 前 台 页 面 的 布局 是 相似 的 ， 痢 是 采用 “上 方 固定 ， 左 侧 谨 套 ”的 框架 结构 。 | 


3 i ee, A x rs Wt A 
由 于 后 台 管 理 主要 是 针对 管理 员 开 放 的 , 普通 用 户 无 法 访问 eet | 删除 的 内 容 : 到 这 里 


删除 的 内 容 : 不 需要 绚 
片 、 极 炫 的 特效 ， 只 要 
整洁 , 给 人 一 种 朴实 无 4 
觉 最 好 。 


{删除 的 内 容 :的 。 
删除 的 内 容 : 功能 如 下 ， 


删除 的 内 容 : 、 


OO 
删除 的 内 容 : 登录 


删除 的 内 容 : ， 该 首页 


在 上 方 框架 (topFrame) 显示 banner 和 首部 导航 : 在 左 侧 框架 (leftFrame) Ma | 删除 的 内 容 : ， 


中 间 的 显示 区 (manFrame) 显示 各 级 窗 体 。 其 具体 的 框架 代码 如 下 : | “删除 的 内 容 : 。 


| 
92971 UD 


人 Be 项 目 业 例 分 析 


| 
| 
mr06Gadminadmin main.ph 一 | 删除 的 内 容 : 下 面 来 看 - 
| 。 fm, een mm ee 
| 01 ”<!-- 定 义 项 部 框架 和 框架 内 显示 的 内 容 --> 程序 代码 如 下 : 
| 02 <frameset rows="88,*" cols="*" frameborder="no" border="1" framespacing="0"> 
| 03 <frame src="top.php" name="topFrame" scrolling="No" noresize="noresize" id="topFrame" 
~ title="topFrame"/> 
| 04 <!-- 定 义 嵌 套 的 左 侧 框架 和 框架 内 显示 的 内 容 --> 
05 <frameset rows="*" cols="216,*" framespacine="0" frameborder="no" border="1"> 
| 06 <frame src="leftphp" name="leftFrame" scrolling="No" noresize="noresize” id= 
"leftFrame" title="leftFrame" /> 
| 07 <!-- 定 义 主 框架 内 容 --> 
| 08 <frame src="main.php" name="mainFrame" id="mainFrame" title="mainFrame" /> 


09 </frameset> 
10 </frameset> 
11 <!-- 当 浏览 器 不 支持 框架 时 所 显示 的 内 容 --> 


12 <noframes><body> 
13 ”</body> 


14 </noframes></html> 
6.7.3 ”后 台 登 录 实现 过 程 
在 后 台 管理 系统 中 ， 首 先 显示 的 是 后 台 管理 员 登录 页 面 ， | 删除 的 内 容 : 展示 


和 密码 之 后 将 跳 转 到 后 台 主页 ， 在 后 台 主 页 中 完成 各 项 管理 操作 。 后 台 管 理 系统 的 登录 页 。“”-{ 删除 的 内 容 : 应 该 
面 如 图 6.22 所 示 。 


办 公 自 栅 化 厄 台 管理 系统 


| 图 6.22 后 台 管理 员 登 录 页 面 

| 当 管 理 员 输入 正确 的 用 户 名 和 密码 之 后 ， 将 跳 转 到 index_ok.php 文件 中 ， 在 该 文件 中 
| 完成 对 用 户 名 和 密码 的 验证 , 登录 成 功 后 将 跳 转 到 admin_main.php 后 台 主 页 。index_ok.php 
| 文件 的 代码 如 下 : 

| 代码 位 置 ， 配套 资源 \mr\06\admin\index_ok.php 


sn: | 中 “| EE 


<?php 
02 header ("Content-type: text/html; charset=gb2312" ); /设置 文件 编码 格式 
| 03 session startO: 
| 04 include "conn/conn php": // 包 含 数据 库 文件 
| 05 include "inc/func .php": 
| 06 Ssqlstr = "select * from th controller where manager=".$ POST["username']."’ and mana 
| pwd=".$ POST['pwadl."™"; 
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07 Sresult = mssql query($sqlstr,Sconn); 

08 Srecord = mssql fetch row(Sresult); 

09 这 Srecord (= ""){ 

10 $_SESSION["m id"] = Srecord[0]: /管理 员 ID 
11 $ SESSION["controller"] =$ POST[msermame']: /| 管理 员 名 称 
jp2 WwW_log($_ POST['action'].$_ SESSION['controller]): /添加 日 志 
13 echo "<script>alert(' 登 录 成 功 "):location='admin_main.php';</script>"; 
14 1 

is else 

16 echo "<script>alert( 用 户 名 或 密码 错误 '):history.go(-1):</script>"; 

| 


说 明 : 

在 本 系统 中 ， 前 台 使 用 的 是 Smarty 模板 完成 网 页 的 动静 分 离 ， 通 过 PDO 对 MS SQL 
Server 2000 数据 库 进 行 操作 。 但 是 ， 在 后 台 管 理 系统 中 没有 应 用 Smarty 模板 ， 操 作 数 据 
库 应 用 的 是 mssql * 函 数 库 。 


当 管 理 员 登 录 成 功 后 ， 将 跳 转 到 admin_main.php 后 台 主 页 ， 以 一 个 frame 框架 完成 后 
台 整 个 主页 的 设计 。 
6.7.4 后 台 主 页 实现 过 程 

后 台 主页 由 frame 框架 文件 adtmin main.php、admin js.js 和 style.css 共同 组 成 。 在 框 


架 文 件 admin_main.php 中 包含 3 个 子 文件 : top.php、left.php 和 main.php。 
top.php 是 框架 的 头 文件 ,输出 网 页 的 头 部 信息 ,创建 前 台 首 页 、 后 台 首 页 和 退出 系统 


代码 位 置 ， 配套 资 源 \mi\06\admin\left.php 


01 <div id=div0 style= "width:216: position:relative"> 

02 <label id=divO class=active style="cursor: hand: background:url(images/left main.jpg): 
width:216:; 

03 height:31: text-align:center; color:#f0f0f0: padding-top:12px"> 部 门 管理 </span></label> 

04 </div> 

05 <div id=divOother style="display:None: width:216"> 

06 <label style="background:url(images/left part.jpg): width:216: height:24: padding-top: 
8px"> 

07 <a href="bmgl/show_depart.php" target="mainFrame"> 查 看 部 门 </a></label> 

08 <label style="background:url(images/left partjpg): width:216: height:24: padding-top: 


-ads 


| 
| 


{删除 的 内 容 : 级 


-11 删除 的 内 容 : 展示 出 
-删除 的 内 容 : js 
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<a href="bmgl/add_depart.php" target="mainFrame"> 添 加 部 门 </a></label> 


09 
10 ”<div> 
其 运行 效果 如 图 6.24 所 示 。 


图 6.24 


后 台 框 架 的 导航 菜单 


代码 位 置 ， 配套 资 源 \mi\06admin\main.php 


01 
02 


<table border="0" cellpadding="0" cellspacing="0"> 


<tr> 


<td colspan="4" height="30" align="center" valign="middle"> 


<a href="xtgl/del slog_chk.php" onClick="return del_chk0:"> 清 除 日 志 </a> 


<td> 
</t> 
<tr> 


<td height="25" align="center"> 登 录 账号 </td> 
<td height="25" align="center"> 登 录 时 间 </td> 
<td height="25" align="center"> 登 录 IP</td> 

<td height="25" align="center"> 登 录 操作 </td> 


</t> 


<?php 
Sfilename = "log.txt": 


这 $f open = fopen($filename."r")){ 
While($str = fgets($f_open.255)){ 
Schr = explode(",",$str): 


echo "<tr>"; 


/定义 日 志文 件 

/打开 日 志文 件 

/循环 读 取 日 志文 件 中 的 数据 
// 对 读 取 的 数据 进行 分 割 


for($i= 0: $i < count($chr): $i++){ /循环 出 查询 结果 
echo "<td align='center height="25'>".$chr[$1]."</td>": 


} 
echo "</tr>": 
} 
fclose($f_open): 
Jelse{ 
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_ /关闭 日 志文 件 
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26 echo "<script>alert( 还 没有 日 志文 件 ! jhistory.go(1):<Jscript>" | 
27 用 | 
57 | 
29 </table> | pp 
| 其 
6.8 部 门 管理 模块 设计 | 医 芝 
一 个 成 熟 、 稳定 的 企业 一 定 要 有 一 个 合理 的 部 门 结构 , 包括 每 个 部 门 需要 做 什么 工作 、 | 
部 门 之 间 的 协调 关系 和 部 门 之 间 的 上 下 级 关系 等 ， 都 要 明确 下 来 ， 这 样 才 能 各 尽 其 职 , 不 | 
i i rr 
会 出 现 资源 浪费 , 提高 企业 整体 效率 。 = .删除 的 内 容 :的 
6.8.1 部门 管 理 模块 概述 | 
i > Ss > | A 
部 门 管理 模块 包括 查看 2 添加 -二 删除 的 内 容 : 包括 
、、 1| 删除 的 内 容 : 大 


查看 各 个 部 门 名 称 和 部 门 之 间 的 上 下 级 关系 ， 对 部 门 的 信息 和 级 别 进行 修改 ， 如 果 是 、、 删除 的 内 容 : 
最 底层 的 部 门 ， 则 可 以 对 其 进行 删除 操作 。 “期 除 的 内 容 : . 
1 § SSE ee EO ee [1 删除 的 内 容 : . 


可 以 添加 新 的 部 门 ， 包 括 部 门 名 称 、 上 级 部 门 和 部 门 备注 。 | 
部 门 管理 操作 流程 如 图 6.25 所 示 。 | 
! 
| 


判断 部 门 名 称 


修改 成 功 | | 修改 部 门 | | | | 开除 部 门 | | 


删除 成 功 


图 6.25 部门 管 理 操作 流程 图 
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| 6.8.2 ”部 门 功能 结构 的 动态 输出 技术 


部 门 管理 上 -1 删除 的 内 容 : : 
会 内 JavaScript 和 递归 函数 来 实现 。 “| 删除 的 内 容 : 的 
一 一 当 用 户 单 击 “ 查 看 部 门 ” 超 链接 时 ， 系 统 开始 查找 tb_depart 数据 库 。 首 先 找到 根部 门 *、、 “删除 的 内 容 :+ 
人 A 谈 F 六 2 [有 by 2 (A 让 2 TI 
判断 第 一 个 根部 门 是 否 有 下 级 部 门 。 如 果 没有 ， 则 直接 输出 部 门 名 称 ， 进 、 带 格式 的 : 正文 ， 缩 进 
行 修改 和 删除 操作 ， 然 后 查找 下 一 个 根部 门 ， 如 果 有 。 则 调用 自 定义 函数 人、 Hr 
3wid Sm)。 其 中 Spam 为 上 级 部 门 D 号 Swid 为 表格 宽度 ;Sm 为 表单 、、、 2 、 
| 元 素 ID 变量 值 。 Ms 删除 的 内 容 : 下 级 部 门 
| 。 丰 8 娄 中, 执 典 Ft CE 
| (1) 查找 上 级 部 门 为 $num 的 部 门 列表 。 \、\ 删除 的 内 容 : : 
| (2) 判断 第 一 个 部 门 是 否 有 下 级 部 门 。 号 3" 删除 的 内 容 : 。 
| (3》 如 果 没 有 ， 则 答 出 部 门 名 称 ， 进行 修改 和 删除 操作 ， 然 后 查找 下 一 个 同 级 部 门 。、 、\ 删除 的 内 容 : 。 
(4) 如 果 有 下 级 部 门 ， 则 再 次 调用 list_menu($num,$wid,&$m) 函 数 。 、、 丽 除 的 内 容 : 这 个 
| (5) 重复 步骤 (1) 一 步骤 (4)。 “出 除 的 内 容 :、 
从 以 上 描述 可 以 看 出 ,Jist menu0 是 个 递归 函数 。 递 归 函 数 删除 的 内 容 : 这 果 ， 相 1 
件 时 ， 函 数 调 用 码 已 经 
| 区 和 
| 如 下: AU 除 的 内 容 : : 
代码 位 置 ， 配套 资 源 \mm\06\admin\inc\func.php A\、 删除 的 内 容 : 正 
| 人 
| 01 <?php \ | 删除 的 内 容 : 自己 
| 02 function list_ menu($num,$wid.&$m){ 删除 的 内 容 : 自己 
03 A _- a 
| 04 $conn = mssql connect("localhost","sa",”"):; > 本 删除 的 内 容 : 
| 05 mssql_select_db("db_office".$conn): 删除 的 内 容 : 
| 06 这 让 宙 光 中 家 宙 家 庙 家 砚 实 员 奖 六 淆 克 用 
| 07 关注 肌 司 级 其 由 :人 天 交 且 生生 本 | 删除 的 内 容 : 
| 08 S$sqlstr = "select * from tb_depart where up_depart =".$Snum:; 1 
| 09 Sresult = mssql_query($sqlstrSconn): 得 除 的 内 容 : 
| 10 /本 村 本 于 未 于 于 于 于 于 村 于 本 于 于 于 宁 于 束 
| n> 
| 12 <!-- 隐藏 域 --> 
| 13 <trid="OpenMe<?php echo $m; ?>" style="display:none:"> 
| 14 <td> <table width="<?php echo $wid: ?>%" border="0" cellspacing="0" cellpadding 
| Bo 
| 15 ”<t> 
| 16 <td height="25" align="center"><table width="<?php echo ($wid -3); ?>96" border="0" cellspacing 
| ="0" cellpadding="0"> 
| 17 。 <?php 删除 的 内 容 
8 二 六 捕 环 入 出 同 级 部 由 和 站 C 2 人 IDC 
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23 二 三 DO 和 
24 WE Sli Sal 下 本村 相让 汪汪 
25 这 !$nmD{ 

26 $m :+t= 1 

2 > 


28 @ <tr onMouseOver="this.style.background="#96F7F4'" onMouseOut= "this.style. 
background=""> | 

29 <td width="100%" align="left">&nbsp:énbsp:;&nbsp:; 

30 <img src="../images/folder.gif" width="16" height="16" border="0"><?php echo $rows[1] ?> 

31 。 <ahre 人 "edit depart.php?id=<?php echo $rows[0]; ?>"> 修 改 </a>|| | 

32<a href="del depart chk.php?id=<?php echo $rows[0]: ?>” onClick="retum cftim0:"> 删 除 | | 
</a></td></tr> 

33 <?php 


5。 TR | 制 除 的 内 容 : 
36 clset | 一-[ 画 除 的 内 容 : 
37 $m += 1: | 


39 <!-- 鼠 标 划 过 样式 -> | 

40 <tr onMouseOver="this.style.background="#96F7F4'" onMouseOut="this.style. | 
background=""> | 

41 @ <td>&nbsp:<a href="Javascript:ShowMe(img<?php echo $m; ?>,OpenMe<? ， 
php echo Sm; ?>)"> 

42<img src="../Images/jia.gif” border="0"” alt=" 展 开 " id="img<?php echo $m; ?>"><?php 
echo $rows[1];?></a> 

43<a href="edit_depart.php?id=<?php echo $rows[0]: ?>"> 修 改 </a>|| 删 除 </td></tr> | 


44 <?php | 

45 © list menu(Srows[0],Swid,Sm); | 

46 } | 

47 ?> | 

48 </table></td></tr></table></td></tr> | 

49 <?php}?> | 
< 关键 代码 解析 


删除 的 内 容 : 代码 贴 十: 


_| 一-[ 弄 除 的 内 容 : 


存放 模 氛 中 ， 同 时 使 用 了 另 一 个 自 定义 函数 jisbook$id.Sdname)， 该 函数 将 $dname | - 击 除 的 内 容 : 这 个 


part 表 中 的 部 门 名 称 一 一 比较 ， 如 果 重 复 ， 则 返回 uss_ 香 则 ,返回 false。 人 参数 -二 两 除 的 内 容 : ， 


数 和 tb_depart 表 中 的 部 门 名 称 一 一 比较 ， 如 果 重 复 ， 则 返回 tusz_ 否 
$id 是 在 修改 部 门 时 ， 先 去 掉 要 修改 的 部 门 的 名 称 再 进行 比较 。 在 信息 处 理 页 中 ， 根据 返 -| 
回 的 值 进行 操作 。isbool0 函 数 的 程序 代码 如 下 : 

代码 位 置 ， 配套 资源 \mr\06\admin\inc\func.php 


01 function isbool($dname){ 
02 Sconn=mssql_connect("localhost"."sa".”™"): __ /连接 数据 库 服务 器 
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| 03 mssql select_db("db_office".$conn): // 连 接 数 据 库 
| 04 $sqlstr = "select * 人 rom tb_depart where d_name =".$dname."";// 定 义 查询 语句 
| 05 Sresult = mssql_query($sqlstr. $conn): /执行 查询 语 名 _ -一 【删除 的 内 容 : 


06 这 mssql_num rows($result)>0) // 获 取 查 询 结果 


| 
| 07 Sisbool = true: 
S| else 


09 Sisbool = false; 
10 Teturn $isbool: 


| TT 


) 沁 
) S 
8 


| 6.8.3 部 门 查看 的 实现 过 程 


本 技术 务必 | | 时 
Fe 


的 程序 代 _ -删除 的 内 容 :根部 站 
| 码 如 下 : 

| 代码 位 置 ， 配套 资源 \mm\06\admin\bmgl\show_depart.php 

| 

| 01 <?php 

| 02 session_ start(); // 开 启 session 

| 03 include "../inc/chec.php": // 包 含 权限 检查 文件 

| 04 include "../conn/conn.php": // 包 含 数据 库 链 接 文件 

| 05 include "../inc/func.php": // 包 含 自 定义 函数 文件 

| 06 > 

07 <script src="../js/admin js.js"></script> /引入 js 脚本 文件 

| 08 <linkhref="../css/style.css" rel="stylesheet"> 引入 外 部 css 样式 -一 二 删除 的 内 容 : 
| 09 <body onLoad="ShowMe(imglLOpenMelD"> /onLoad 事件 ， 表 示 当 页 面 被 载 入 


10 ”<!-- 查 看 部 门 信息 --> 
11 <table width="100%" height="25" border="0" cellpadding="0" cellspacing="0"> 
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12 <?php 
13 ed 
14 $sqlstr = "select * from tb_depart where top_depart = 0"; 
15 Sresult = mssql query($sqlstr$conn): 
16 TD 
17 Sm=1; 
18 让 证 环 外 出 所 有 根 刻 | 
19 while($rows = mssql fetch row($resul)){ 
20 S$wid = 100; 
2150 6 生态 民 攻 生 本 让 全 和 让 生生 生生 全 下 于 
22 $sqlstrl = "select * from tb depart where up_depart = ".$rows[0]: 
23 Sresultl = mssql query($sqlstr1.Sconn): | 
24 S$nu = mssql num rows(Sresultl): | 删除 的 内 容 : 
25 和 时 当前 广 站 没有 胸部 门 2 -型 除 的 内 容 ， 
26 if(!Sn){ ~ 
27 和 | WU 的 内容 ___ 
28 <tr onMouseOver="this.style.background="#96F7F4'" onMouseOut="this.style. | 
background=""> | 
29 <td>&nbsp:&nbsp:&nbsp:&nbsp:<a href="<?php echo SPHP SELF; ?>"> 


30 <img src="../Images/folder.gif' border="0" alt=" 展 开 " id="img<?php echo $m: ?>"><?php | 
echo $rows[1]: ?> 

31 </a>- 一 一 一 一 一 -<ahref-"edit departphp?id=<?php echo $rows[0]: ?>"> 修 改 </a>|| 

32 <a href="del depart chk.php?id=<?php echo $rows[0] ?>”onClick="retum cfm0:"> 删 除 


</a></td> | 
33 </tr> | 
34 <? | 
35 公克 果 当 抽 部 问 及 讽 训 站 放 21 半 和 | -出 除 的 内 容 : 
2 EX | 一-[ 画 除 的 内 容 : 
37002> | 
38 <tr onMouseOver="this.style.background="#96F7F4'" onMouseOut="this.style. 
background=""> | 
39 <td><a href="Javascript:ShowMe(img<?php echo $m: ?>.OpenMe<?php echo | 
Sm; ?>)"> 


40 ”<img src="../Images/jia.gif" border="0" alt=" 展 开 " id="img<?php echo $m: ?>"><?php echo 
$rows[1]; ?></a> 
41 <ahref="edit depart.php?id=<?php echo $rows[0]: ?>"> 修 改 </a>|| 删 除 </td> | 


42 </t> | 
43 <?php | 

445 轩 /入 出 同 奴 部 问 宫调 用 讽 归 二 煌 2 _| -一 {删除 的 内 容 : 

45 list_ menu(Srows[0],Swid,Sm); 的 删除 的 内 容 : 

46 $m+= 1; | 

47 


六 | 
A et ER td _| {删除 的 内 容 : 
> ! 


单 击 要 修改 的 部 门 名 称 后 面 的 “修改 ” 超 链 接 可 进入 修改 部 门 页 面 。 修 改 部 门 页 面 的 运行 
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图 6.27 修改 部 门 页 面 的 运行 结果 
修改 部 门 页 面 edit_ departphp) 中 的 主要 表单 元 素 如 表 6.12 所 示 。 
表 6.12 修改 部 门 页 面 中 的 表单 元 素 


<?php 


while($tmprows = mssql_fetch_array($tmpresulD){ 

if($tmprows[id] 一 $rows[top_depart){ 

echo "<option value=".$tmprows[id]. 
selected>".$tmprows[d_name]."</option>"; | > 

JE 列 出 所 有 部 门 


| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | textarea | <?php echo $rows[remark] ?> 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
J 


echo "<option value=".$tmprows[id].">".$tmprows 
[d_name].” 
</option>"; 
修改 部 门 的 ID 
| submit | name="Submit" value=" 修 改 " onclick="return a_checkO:" 

当 管 理 员 修改 完 相应 的 信息 单 击 “ 修 改 ” 按 钮 提交 修改 信息 后 ， 系 统 转 到 处 理 页 
”edit_depart_chk:php)， 首 先 判 断 输 入 的 部 门 名 称 是 否 重复 ， 如 果 重 复 ， 则 返回 ， 如 果 不 
| 重复 ， 则 继续 执行 ， 确 定 修改 后 的 上 级 部 门 和 根部 门 ， 关 键 代码 如 下 : 

代码 位 置 ， 配 套 资源 mi\06\admin\bmgledit_depart_chk.php 

01 <Iphp 
02 session startO; /开启 session 
03 include "../inc/chec.php":; // 包 含 权 限 检查 文件 
04 include "../conn/conn .php": /包含 数据 库 链 接 文件 
05 include "../inc/func.php": // 包 含 数据 库 链 接 文 件 
06 /判断 输入 部 门 名 称 是 否 重复 4/ 
07 iftisbool($ POST[id].$ POST[d name])){ 
08 echo "<script>alert( 名 称 已 存在 ， 请 重新 输入 !!"):history.go(-1):</script>"; 
09 exitO: 
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: 
11 ”/* 修 改 部 门 ， 确 定 上 级 部 门 和 根部 门 */ 
12 ”这 $ POSTIu id] !=){ 
13 ”A* 查 找 上 级 部 门 的 根部 门 */ 


14 Ssqlstr = "select top_depart from tb_depart where id =".$ POST[u id]; 

15 Sresult = mssql query($sqlstr$conn): 

16 Srows = mssql fetch array(Sresulf); 

17 ”/* 如 果 存在 上 级 部 门 ， 就 取得 上 级 部 门 的 根部 门 */ 

18 if ($rows[top_depart] != 0) 

19 Stop_depart = $rows[top_depart]; 

20 ”/* 如 果 不 存 在 ， 将 上 级 部 门 作为 根部 门 */ 

2 else 

22 Stop_depart = $_ POST[u id]; 

23 jelse 

24 ”/* 如 果 没 有 上 级 部 门 ， 那 么 就 将 自身 定 为 根部 门 */ 

25 Stop_depart = 0: 

26 /* 创 建 、 执 行 修改 部 门 的 SQL 语句 */ 

27 Ssqlstr = "update tb depart set d name = '".$ POST[d namel]."',top depart = | 
"Stop_depart.", 


28 up depart = ".$ POST[u id].", remark = '".$ POST[remark]."" where id = 
".$ POSTI[idl]; 


29 Sresult = mssql_query($sqlstr, $conn); 
30 re message($result."show depart.php"): 
31 > 


(2) 删除 部 门 

如 果 要 取消 某 个 部 门 ， 可 以 将 该 部 门 删除 。 在 删除 部 门 时 ， 只 能 对 最 底层 的 部 门 进行 
删除 ， 如 果 部 门下 面 有 子 部 门 ， 其 部 门 后 面 的 “删除 ” 超 链 接 不 可 用 。 删 除 功 能 的 实现 相 
对 比较 简单 ， 单 击 “ 删 除 ” 超 链接 后 ， 系 统 提示 是 否 确认 删除 部 门 ， 如 果 单 击 “ 确 认 ” 按 
钮 ， 系 统 将 转 到 处 理 页 (del_depart_chk.php〉 进 行 删除 处 理 。 程 序 代 码 如 下 : 

代码 位 置 ， 配套 资 源 \mi\06\admin\bmgl\del_depart_chk.php 


01 <?php 

02 session start(): /开启 session 

03 include "../inc/chec.php": // 包 含 权 限 查 看 文件 
04 include "./conn/conn php": /包含 数据 库 链接 文件 
05 。 include "./inc/func php": // 包 含 自 定义 文件 

06 $sqlstr="delete from {tb depart whereid=".$ GET[id]; // 删 除 SQL 语句 

07 Sresult=mssql query($sqlstr.$conn): // 执 行 SQL 语句 

08 re message($result."show depart.php"): // 返 回 最 后 结果 

09 > 


6.8.4 ”部 门 添加 的 实现 过 程 
单 击 “部 门 管理 ”/“ 添 加 部 门 ” 超 链接 ， 可 以 进入 添加 部 门 页 面 (add_depart.php)， 
该 页 面 用 于 设置 新 添加 部 门 的 相关 信息 ， 包 括 部 门 名 称 、 上 级 部 门 和 备注 。 添 加 部 门 页 面 
的 运行 结果 如 图 6.28 所 示 。 
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图 6.28 ”添加 部 门 页 面 的 运行 结果 


添加 部 门 页 面 (add_depart) 主要 包含 一 个 添加 部 门 表 单 ， 表 单元 素 的 名 称 、 说 明 及 


属性 值 如 表 6.13 所 示 。 


表 6.13 添加 部 门 页 面 的 表单 元 素 


<?php 
while($rows = mssql fetch row(S$resultl)) 
echo "<option value=". $rows[0].">".$rows[1]. "</option>"; 


?> 


textarea 


<2 


Session_start(: /开启 session 

include ". /inc/chec php": // 包 含 权限 检查 文件 
include "../conn/conn.php":; // 包 含 数据 库 链 接 文件 
include "../inc/func.php": // 包 含 自 定义 函数 文件 
证 判 断 输入 部 门 名 称 是 否 重复 */ 


if(isbool($ POST[d name]))f 
echo "<script>alert(' 名 称 已 存在 ， 请 重新 输入 !!"):history.go(-1):</script>"; 
exit(); 


} 
族 确 定 上 级 部 门 和 根部 门 */ 
if($ POSTFu id] !{="0"){ 
Ssqlstr = "select top_depart from tb_depart where id =".$ POST[u id]; 
Sresult = mssql query($sqlstr.Sconn): 
S$rows = mssql fetch row($result): 
if ($rows[top_depart] (= 0) 
S$top_depart = $rows[top_depart]: 


else 
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19 S$top depart=$ POST[u id]: | 

20 } | 

2 else | 

22 S$top_depart= 0: 

23 人 # 添 加 新 部 门 妇 

24 $sqlstr = "insert into tb depart values(",".$ POST[d name].".".$top depart.", ns pOsT | 
[uid].",".$ POST[remark].")": 

25 $result = mssql query($sqlstrSconn): 

26 /输出 添加 结果 所 

27 re_message(Sresult,"show_depart.php") 


6.9 系统 管理 模块 设计 


系统 管理 模块 在 后 台 系 统 中 占据 着 非常 重要 的 位 置 ， 后 台 的 其 他 模块 都 是 针对 前 台 功 
能 而 设计 的 ， 而 系统 管理 模块 是 针对 系统 本 身 的 一 些 信 息 、 情 况 而 设计 的 ， 一 般 包括 数据 | 
备份 、 管 理 员 信息 修改 等 ， 甚 至 可 以 对 操作 系统 的 配置 文件 进行 操作 ， 可 以 说 是 管理 员 的 | 
管理 员 ， 是 后 台 系 统 中 必 不 可 少 的 组 成 部 分 。 | 


6.9.1 系统 管理 模块 概述 


系统 管理 模块 的 功能 有 : 
回 ”系统 日 志 : 记录 了 前 、 后 台 用 户 登 录 时 的 相关 信息 。 
回 ”修改 密码 : 修改 后 台 管理 员 登 录 密 码 。 


6.9.2 ”通过 文件 存储 数据 技术 


在 系统 管理 模块 中 ， 保 存 数 据 的 方式 包括 数据 库 和 文件 ， 数 据 库 技 术 在 此 不 再 袭 述 。 
本 节 主 要 讲解 文件 及 文件 夹 的 相关 操作 。 | 
对 文件 的 操作 主要 分 3 步 : 打开 文件 、 读 取 / 写 入 文件 、 关 闭 文件 。 | 
(1) 打开 文件 | 
打开 文件 使 用 fopen0 函 数 ， 其 语法 格式 如 下 : 


好 
MNote 


int fopen (string filename.string mode ); |， --( 带 格式 的 : 项 目 符号 和 


其 中 ， 参 数 flename 是 要 打开 的 包含 路 径 的 文件 名 ， 可 以 是 相对 路 径 或 绝对 路 径 。 如 | 
果 没 有 任何 前 级 ， 则 表示 打开 的 是 本 地 文件 ， 参 数 mode 是 打开 文件 的 方式 ， 常 用 的 有 a | 
(追加 )、w 只 写 ) 和 r (只 读 )。 代 码 如 下 : 


$f open = fopen("../bak/remark.sql"."at+"): -一 


(2) 读 取 / 写 入 文件 | 
读 取 文件 的 函数 较 多 ， 最 常用 的 就 是 按 行 读 取 fgets0 函 数 ) 和 全 部 读 取 (readfile() 
和 fpassthru0 函 数 )。 
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fgets0 函 数 的 一 般 格式 为 : 

| string feets ( int filename [ .int length ]) : -| 带 格式 的 : 项 目 符号 和 
其 中 ， 参 数 flename 是 被 打开 的 文件 ， 参数 length 是 要 读 取 的 数据 长 度 。 函 数 能 够 实 

现 从 filename 指定 的 文件 中 读 取 一 行 并 返回 长 度 最 大 值 为 length-1 个 字 节 的 字符 串 ， 在 遇 

到 换行 符 、EOF 或 者 读 取 了 length-1 个 字 节 后 停止 。 如 果 没有 指定 length 的 长 度 ， 默 认 值 

是 1KB。 代 码 如 下 : 


<?php 
$f open = fopen ("../bak/remak.txt"."r") : /打开 文本 
echo fgets ( $f open) : // 读 取 其 中 的 数据 
felose ( $f open ) : 
9 


readfile0 函 数 的 一 般 格式 为 : 
int readfile ($filename ); -| 带 格式 的 : 项 目 符号 和 
| 其 中 ， 参 数 $filname 为 要 打开 的 文件 名 ， 使 用 该 函数 时 ， 无 需 打 开 和 关闭 文件 ， 也 无 
| 需 输 出 语句 echo， 直 接 读 取 文 件 的 全 部 内 容 并 显示 在 页 面 中 即 可 。 


(3) 关闭 文件 
完成 对 文件 的 操作 后 ， 就 可 以 关闭 文件 了 。 关 闭 文件 的 命令 十 分 简单 ， 格 式 如 下 : 
fclose ( $open): *---:| 带 格式 的 : 项 目 符号 和 


其 中 ， 参 数 $open 是 要 关闭 的 文件 资源 。 
| 在 本 模块 中 ， 还 用 到 一 个 自 定义 函数 c log0。c_log0 函 数 的 作用 是 删除 日 志文 件 ， 函 
| 数 代 码 如 下 : 
代码 位 置 ， 配套 资源 \mr\06\admin\inc\func.php 
01 function ¢ logO{ 


02 Sfilename="../log.txt"; /日 志文 件 路 径 

03 if(file_exists(Sfilename)) /判断 文件 是 否 存在 

04 unlink(Sfilename); // 如 果 文 件 存在 ， 删 除 

05 else // 如 果 文 件 不 存在 ， 返 回 上 层 操作 
07 } 


| 6.9.3 ”系统 日 志 的 实现 过 程 


| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 06 echo "<script>alert( 暂 无 系统 日 志 ! "):history.go(-1):</script>"; 

| 

| 单 击 “ 系 统管 理 ”/“ 系统 日 志 ” 超 链接 ， 可 进入 系统 日 志 页 面 。 在 该 页 面 中 显示 系统 
| 日 志 信息 ， 在 系统 日 志 中 ， 记 录 着 前 、 后 台 ， 包 括 普通 用 户 和 后 台 管理 员 所 有 人 员 登 录 系 
| 统 时 的 信息 ， 包 括 登录 时 间 、 用 户 账号 、 登 录 IP 等 。 这 些 信息 是 在 用 户 登录 时 系统 自动 
| 添加 到 数据 表 中 的 《关于 用 户 登录 的 实现 请 参见 本 书 配套 资源 )。 系 统 日 志 页 面 的 运行 结 
| 果 如 图 629 所 示 。 

| 

] 
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图 6.29 系统 日 志 页 面 的 运行 结果 

显示 日 志 是 对 文件 进行 读 取 ， 定 位 到 日 志文 件 log.txt 后 ， 使 用 fgets0 函 数 读 取 日 志 内 | 
容 ， 并 显示 在 页 面 中 ， 程 序 代码 如 下 : | 
代码 位 置 : 配套 资源 mr\06admin\xtglslog.php 


01 <?php 

02 session start(O); /开启 session 支持 

03 include "inc/chec php": // 包 含 权限 检查 文件 

04 > ! 
05 <script sre="../js/admin jsjs"></script> /引入 JS 脚本 文件 | 
06 。 <link href="../css/style.css" rel="stylesheet"> /引入 外 部 CSS 样式 文件 | 
07 | 
08 <tr> | 


09 <tdcolspan="4" height="30" align="center" valign="middle"> 
10 <ahref="del slog_chk.php" onclick="return del_chk0;"> 清 除 日 志 </a></td> 


11 </t> 

1 

13 <?php 

14 Sfilename = "../log.txt"; // 日 志文 件 路 径 | 
15 if(Sf_ open = fopen(Sfilename,"r")) { /是否 以 只 读 形式 打开 文件 | 
16 while(Sstr = fgets(Sf_open,255))f // 按 行 读 取 日 志文 件 内 容 | 
17 Schr = split(",",Sstr); // 以 “, ”为 分 隔 符 ， 返 回 数组 形式 的 记录 集 | 
18 echo "<tr>"; | 
19 for($i = 0; Si< count(Schr); SID{ // 循 环 输出 字段 值 | 
20 echo "<td align='center height="25'>". $chr[$i]."</td>": } | 
21 echo "</tr>":} | 
22 felose($f open): /关闭 文件 : 
23 } else // 没 有 日 志文 件 时 | 
24 ”echo "<script>alert( 还 没有 日 志文 件 ! '):history.go(-1):</script>"; 

25. > 

26 </table> 


27 </td></tr></table> 
对 于 无 用 的 日 志 信息 需要 定期 消除 ， 单 击 页 面 中 的 “清除 日 志 ” 超 链接 可 清空 日 志 ， 
实际 上 就 是 删除 日 志文 件 ， 程 序 代 码 如 下 : 
代码 位 置 ， 配 套 资源 \mi\06\admin\xtghdel_slog_chk.php 


01 <?php 
02 session start(); // 开 启 session 支持 
03 include "../inc/chec.php": // 包 含 权 限 检查 文件 
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| 04 include "../inc/func.php": // 包 含 自 定义 函数 文件 
| 05 clog0; // 调 用 自 定义 函数 

| 06 echo "<script>alert( 删 除 成 功 ! "):location='data_stock.php':</script>"; 

| 07 ?> 

| 


权限 管理 模块 在 后 台 系统 中 控制 用 户 以 及 用 户 组 的 权限 ， 决 定 在 前 台中 登录 的 用 户 属 
于 哪个 用 户 组 ， 拥 有 什么 样 的 权限 。 


| 6.10.1 权限 管理 模块 概述 


权限 管理 模块 的 功能 有 : 

回 ”账号 权限 : 控制 用 户 是 否 具有 在 前 台 登 录 本 系统 的 权限 。 

回 用 户 组 设置 : 完成 用 户 组 的 创建 ， 组 员 的 添加 、 修 改 和 删除 操作 。 
回 权限 分 配 : 设置 每 个 用 户 组 具备 的 权限 。 


| 6.10.2 ”使 用 JavaScript 关联 多 选 列表 框 


| 在 本 系统 中 ， 多 个 模块 都 使 用 了 这 种 技术 ， 即 在 两 个 多 选 列表 框 之 间 产生 关联 ， 从 列 
| 表 框 A 中 删除 的 数据 被 相应 地 添加 到 列表 框 B 中 ， 反 之 ， 从 列表 框 B 中 删除 的 数据 会 被 
| 添加 到 列表 框 A 中 。 

权限 管理 模块 中 的 用 户 组 设置 ， 就 用 这 种 技术 实现 了 “添加 新 用 户 组 ”功能 。 首 先 在 
| 左 侧 的 多 选 列表 框 中 选择 要 添加 的 成 员 ， 单 击 “ 添 加 组 员 ” 超 链接 ， 被 选中 的 成 员 就 被 添 
| 加 到 右 侧 列表 框 ， 同 时 删除 在 左 侧 列表 框 中 的 成 员 ， 运 行 结果 如 图 6.30 所 示 。 


用 户 组 : [Ea 用 户 租 : [EE 
[EE dd cece 
[aa 
添加 组 员 》》 添加 粗 员 >> 
《< 删除 组 员 《< 出 除 姐 员 
EE 


图 6.30 使 用 JavaScript 关联 多 选 列表 框 
下 面 来 看 一 下 有 具体 的 操作 。 首 先 创建 一 个 表单 ， 其 中 两 个 多 选 列表 框 为 必 选 的 表单 元 
素 ， 分 别 命名 为 left 和 right， 放 在 左 、 右 两 边 ， 其 中 ，left 列表 框 中 的 数据 是 从 数据 库 中 
| 读 取 的 ，right 列表 框 则 初始 为 空 ， 程 序 代 码 如 下 : 
代码 位 置 ， 配套 资源 \mr\06\admin\qxghadd group.php 


01 En 
02 ”<!-- 输 出 左 侧 列表 框 -> 


6.10 权限 管理 模块 设计 
| 
| 
| 
| 
| 
| 
| 
| 
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03 <SELECT name="left" size="10" multiple style="width:100px: "> 


04 <?php 

05 while(Srows = mssql fetch row(Sresulb){ 

06 echo "<option value=". $rows[1].">".$rows[1]."</option>": /从 数 | 
据 库 中 读 取 列表 值 

07 } 

08 > 

09 < 人 SELECT> 

10 < > 

Mn </td> 

12 <!-- “添加”、“ 删 除 ” 超 链接 --> 

13 <tdwidth="96" align="center" valign="middle"> 

14 <a href="#" onClick="activeList(document.form1.left,document.form1.right)"> 添 加 组 | 
员 &gt&gt</a><br> 

15 <br> 

16 <a href="#" onClick="activeList(document.form1.right,document.form1.left)">&lt:&lt: | 
删除 组 员 </a></td> 

17 ”<!-- 右 侧 列表 框 -> 

18 <td colspan="2" align="center" valign="middle"><select name="right" size="10" multiple 
style="width:100px: "> 

i9 ‘</select></td> 

20 </u> 

2 <tr> 

22 <td height="30" colspan="4" align="center" valign="middle"> 

23 <input type="hidden" name="g list" /> 

24 <!-- “添加 ”按钮 -> 

25 <input type="submit" value=" 添 加 " onclick="return glist0" /><input type="reset" 
value=" 重 置 " /> 

26 


上 面 的 代码 主要 采用 HTML 和 PHP 语言 ， 和 普通 的 页 面 没有 什么 区 别 ， 核 心 的 语句 
就 是 代码 中 的 加 粗 部 分 ， 当 单 击 “添加 组 员 ” 或 “删除 组 员 ” 超 链接 时 ， 将 触发 JavaScript 
脚本 事件 ， 执 行 activeListO 函 数 ， 函 数 代 码 如 下 : 
代码 位 置 ， 配套 资源 mi\06\adminjsadmin js.js 
01 ”/* 关 联 多 选 列表 


02 ”*headStream: 源 多 选 列表 
03 ”*endStream: 目的 多 选 列表 


04 2 

05 function activeList(headStream.endStream){ 

06 var valueList = new Array(): /| 数组 ， 用 来 存储 要 移动 数据 的 value 值 
07 var textList = new Array0O: /数组 ， 用 来 存储 要 移动 数据 的 text 值 
08 var valueTmpText = new Array0: // 数 组, 用 来 存储 要 移动 数据 的 option 项 
09 var index = 0: /数组 下 标 

10 。 必 存 储 源 列表 中 的 被 选中 的 数据 3/ 

和 for(var 二 0: i<headStream.options.length: i++){ 

Eb4 if(headStream.options[i].selected){ // 判 断 元 素 是 否 被 选中 

13 valueList[index] = headStream_.options[i.value: /存储 value 值 

14 textList[index] = headStream.options[i].text: /存储 text 值 

15 valueTmpText[valueList[index]] = headStream.options[i]: /存储 option 项 
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| 

| 16 index ++; 

| 1 上 

| 18 } 

| 19 。 人 # 向 目的 列表 中 添加 数据 ， 同 时 删除 对 应 的 源 列表 数据 所 

A | 20 for(var i=0: i<textList.length: i++) { 
全 站 | 2 Var foption = document.createElement("option"): // 建 立新 的 option 项 

| 22 foption text = textList[i]: 
24 endStream.add(foption); // 向 目标 列表 添加 新 建 option 项 
25 headStream removeChild(valueTmpText[valueList[i]): /从 源 列 表 中 移 除 option 项 
26 上 
27 } 


6.10.3 ”账号 权限 


在 权限 管理 模块 中 ， 第 一 个 功能 就 是 设置 账号 的 权限 ， 它 由 accounts_purview.php 和 
”modify_purview_chk.php 两 个 文件 组 成 。 在 accounts_purview.php 文件 中 ,循环 输出 用 户 数 
| 据 表 中 的 数据 ， 并 且 设置 开启 和 禁用 权限 的 超 链 接 ， 链 接 到 modify_purview_chk.php 文件 


| 中 ， 在 该 文件 中 完成 对 用 户 权 限 的 设置 操作 ， 其 运行 效果 如 图 6.31 所 示 。 
序号 账号 姓名 部 门 吾 用 开启 

1 1003 小 军 C++ 将 司 开启 

2 1002 小 困 质量 部 兹 局 开启 

3 1001 小 王 人 事 部 禁用 开启 

4 1006 批评 ve 茜 司 开启 


图 6.31 账号 权限 设置 
accounts_purview.php 的 关键 代码 如 下 : 
代码 位 置 ， 配套 资源 \mm\06\admin\qxgl\accounts purview.php 
01 /<2php 
02 ”header ("Content-type: text/html: charset=gb2312" ): /1/ 设 置 文件 编码 格式 
03 include "../inc/chec.php": 


04 include"../conn/conn.php": 
05 finclude "../inc/func.php": 


06 > 

07 <?php 

08 $sqlstr="selectidu user.u name.u depart.is on from tb users"; /定义 SQL 语句 

09 Sresult= mssql query($sqlstr.$conn): // 执 行 SQL 语句 

10 /while($Srows=mssql fetch row($result){ /循环 输出 查询 结果 
11 > 

12 <tr> 

13 <td height="25" align="center" valign="middle"><?php echo $rows[0]; ?></td> 
14 <td align="center" valign="middle"><?php echo $rows[1]: ?></td> 

15 <td align="center" valign="middle"><?php echo $rows[2]: ?></td> 

16 <td align="center" valign="middle"> 

17 <?php echo read field($conn."tb_depart"."d_name",.$rows[3]): ?> 


23 foption.value = valueList[i]: 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
] 
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Bd | 

18 </td> | 

19 ”人 ?php if(Srows[4] — D{ ?> | 

20 <td align="center" valign="middle"> | 

21 <a hre 人 "modify purview_chk.php?id=<?php echo $rows[0]: ?>&is_on=0"> 禁 用 | 
</a></td> | 了 

2 <td align="center" valign="middle"> 开 启 </td> | 全 中 

23 <?php}else{ ?> | 

24 <td align="center" valign="middle"> 禁 用 </td> Note 

25 <td align="center" valign="middle"> | 

26 <a href="modify_purview_chk.php?id=<?php echo Srows[0]: ?>&is on=1"> 开 启 ， 
</a></td> | 

27 。 <?php } 2> | 

28 </t> | 

29 <?php } 2> 


在 modify purview_chk.php 文件 中 ， 根 据 超 链 接 传递 的 参数 值 执行 更 新 语句 ， 完 成 对 
用 户 权限 的 设置 操作 ， 其 代码 如 下 : 
代码 位 置 ， 配套 资源 \mr\06\admin\qxgl\modify_purview_chk.php 


01 <?php | 
02 ”header ("Content-type: text/html: charset=gb2312"); /设置 文件 编码 格式 | 
03 include "../inc/chec.php": // 载 入 自 定义 函数 | 
04 include "./conn/conn php": // 载 入 数据 库 链接 文件 


05 $sqlstr="update tb_users setis on=".$ GET['is on]." whereid="$_ GET[id]; /定义 


06 。 $result = mssql query($sqlstr,Sconn): /执行 更 新 语句 

07 if($result) 

08 echo "<script>alert(' 修 改 成 功 ! "):location='accounts_purview.php';</script>"; 
09 else 

10 echo "<script>alert(' 系 统 繁忙 ， 请 稍 后 再 试 "):history.go(-1):</script>"; 

11 > 


6.10.4 用 户 组 设置 


在 用 户 组 设置 中 实现 用 户 组 的 创建 、 修 改 和 删除 功能 。 一 方面 将 同一 用 户 分 配 到 不 同 | 
的 用 户 组 中 ， 另 一 方面 为 不 同 的 用 户 组 设置 不 同 的 权限 ， 从 而 达到 用 户 权 限 的 细 化 ， 防 止 | 
系统 被 恶意 破坏 。 其 中 添加 用 户 组 和 组 员 的 运行 效果 如 图 6.32 所 示 。 


局 疡 组 部 门 经 理 | 

不 盏 
小 王 | 
批评 | 
《< 到 除 组 员 | 
| 
| 
| 


6.32 添加 用 户 组 和 组 员 
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人 ie 项 目 业 例 分 析 


(1) 用 户 组 的 创建 
用 户 组 的 创建 关键 是 add_group.php 和 add_group_chkphp 两 个 文件 .在 add_group.php 
| 文件 中 创建 form 表单 ， 提 交 用 户 组 ， 添 加 和 删除 组 员 。 其 关键 代码 如 下 : 
| 代码 位 置 ， 配套 资源 \mr\06\admin\qxgladd_group.php 


01 <form name="forml" method="post" action="add group_chkphp"> 
02 <table width="450" border="0" cellpadding="0" cellspacing="0"> 


| 03 <tr> 
| 04 <td height="25" colspan="4" align="center" valign="middle" scope="col"> 用 户 组 : 
| 05 <input type="text" name="u_ group" /> <td> 
| 06 </tr> 
| 07 <t> 
| 08 <td width="189" align="center" valign="middle"> 
| 09 <SELECT name="left" size="10" multiple style="width:100px: "> 
| 10 <2php 
| 11 while($rows = mssql fetch row(Sresulb){ 
| 12 echo "<option Value=".$rows[1].">".$rows[1]."</option>”: 
| 13 } 
| 14 > 
| 15 </SELECT> </t> 
| 16 <td width="96" align="center" valign="middle"> 
| 17 <a href="#" onClick="moveSelected(document.form1.left,document.form1.right)"> 添 
”加 组 员 &gt:&gt:</a> 
| 18 <br> 
| 19 <a href="#" onClick="moveSelected(document.forml.right,document.form1.left)"> 
| 删除 组 员 </a></td> 
| 20 <td colspan="2" align="center"” ><select name="right" Size="10” mnultiple 
‘style="width:100px; "> 
| 21 </select></td> 
| 22 </tr> 
| 23 <tr> 
| 24 <td height="30" colspan="4" align="center" valign="middle"> 
25 <input type="hidden" name="g list" /> 
| 26 <input type="submit”value=" 添 加 ”onclick="return glist0" /><input type="reset" 
| value=" 重 置 "/> </td> 
| 27 </tr> 
| 28 </table> 
| 29 </form> 


其 中 ， 添 加 和 删除 组 员 是 通过 onClick 事件 调用 JavaScript 脚本 中 的 moveSelected0 方 
， 法， 实现 数据 的 添加 和 删除 操作 。 

| 在 add_group_chk.php 文件 中 ， 获 取 表单 提交 的 数据 ， 将 数据 添加 到 指定 的 数据 表 中 ， 
”其 关键 代码 如 下 : 

代码 位 置 ， 配套 资源 \mr\06\admin\qxghadd group_chk.php 


01 <?php 
02 header ("Content-type: texthtml: charset=gb2312" ): /设置 文件 编码 格式 
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™ Sm level.™)": 
07 


include "../inc/chec.php": // 载 入 自 定义 函数 


include "../conn/conn php": // 载 入 数据 库 连 接 文 件 

Su level=$ POST['g list]: /获取 提交 的 数据 

$sqlstr = "insert into tb group(u group.u member) values(".$ POST ['u group'].", 
$result = mssql query($sqlstr$conm): // 执 行 添加 语句 

if($result) 


echo "<script>alert(' 操 作成 功 ! "):location="user_group.php':</script>"; 
else 

echo "<script>alert(' 系 统 繁忙 ， 请 稍 后 再 试 '):history.go(-1):</script>"; 
?> 


(2) 用 户 组 修改 

用 户 组 修改 由 modify group.php 和 modify group chk.php 两 个 文件 组 成 。 在 
modify_group.php 中 ,根据 超 链 接 传 递 的 ID 值 ， 从 数据 库 中 读 取出 该 用 户 组 的 数据 ， 然 后 
调用 JavaScript 脚本 中 的 moveSelected0 方 法 ， 实 现 数 据 的 添加 和 删除 操作 ， 最 终 提交 到 
modify_group_chk.php 文件 中 ， 完 成 对 用 户 组 数据 的 更 新 操作 。modify_group.php 的 关键 


代码 如 下 : 


代码 位 置 ， 配套 资源 \mi\06\admin\qxgl\modify_group.php 


01 
02 
03 
04 
05 

义 SQL 语句 
06 


<? 

header ( "Content-type: text/html: charset=gb2312" ): // 设 置 文件 编码 格式 

include "../inc/chec.php"; 

include "../conn/conn php": 

$sqlstr = "select * from tb_group where id=".$_ GET[id]: /以 超 链接 传递 的 值 为 条 件 定 


$result = mssql_query($sqlstr, Sconn): // 执 行 查询 语句 

Srows = mssql_fetch_row($result): // 获 取 查 询 结果 

Slist = explode(",". $rows[2]):; // 将 查询 的 字符 串 分 隔 读 取 到 数组 中 
2 


<form name="forml" method="post" action="modify group_chk.php"> 
<table width="450" border="0" cellpadding="0" cellspacing="0"> 


<tr> 
<td height="25" colspan="4" align="center" valign="middle" scope="col"> 用 户 组 : 
<input type="text" name="u_group" value="<?php echo $rows[1] ?>" /></td> 
</t> 
<tr> 
<td width="186" align="center" valign="middle"> 
<SELECT name="left" size="10" multiple style= "width:100px: "> 


<?php 
$sqlstrl = "select idu_name from tb_users": /定义 SQL 语句 
Sresult] = mssql_query($sqlstrl.$conm): /查询 用 户 表 中 数据 
while($rowsl = mssql_fetch_row($result1){ /循环 输出 查询 结果 
$bool =tme: 
for($num = 0: $num < count($list): $num++) { 1/ 循环 读 取 数组 中 数据 
if($rows1[1] 一 $list[Soum]){ /判断 数据 是 否 相同 
$bool= false: 
break: 


20s 


28 
29 } 
30 if($bool — true) 
3 echo "<option value=". $rows1[1].">".$rows1[1]."</option>": 
3 | 
33 > 
34 </SELECT> ”</td> 
35 <td width="94" align="center" valign="middle"> 
36 <a href="#" onClick="moveSelected(documentforml.lefbdocumentforml.righb"> 
”添加 组 员 &gt:&gt:</a> 
37 <br> 
38 <a href="#" onClick="moveSelected(document.forml.right,document.form1.left)"> 
删除 组 员 </a></td> 
E <td colspan="2" align="center" valign="middle"> 
40 <select name="right" size="10" multiple style= "width:100px: "> 
41 <?php 
42 for($i = 0; $i < count($lisb - 1: Si+H){ 
43 echo "<option value=".$list[$i].">".$list[$i]."</option>"; 
4 
45 os 
46 </select></td> 
47 </tr> 
48 <tr> 
49 <td height="30" colspan="4" align="center" valign="middle"> 
50 <input type="hidden" name="g list" /> 
si <input type="hidden" name="id" value="<?php echo $_GET["id']: ?>"> 
52 <input type="submit" value=" 修 改 " onclick="return glist0" /> </td> 
53 </t> 
54 </table> 
55 </form> 


在 modify_group_chk.php 文件 中 , 获取 form 表单 提交 的 数据 , 完成 对 指定 用 户 组 数据 
的 更 新 操作 。 其 关键 代码 如 下 : 
代码 位 置 ， 配套 资源 \mr\06\admin\qxgl\modify_group_chk.php 


01 
02 


<?php 

header ( "Content-type: text/html: charset=gb2312" ); /设置 文件 编码 格式 

include "../inc/chec.php": 

include "../conn/conn .php": 

$sqlstr = "update tb_group set u group = ".$ POST['u group'].", u member = ".$_ POST 


where id=".$_POST[id']: 
Sresult = mssql query($sqlstr.$conn): 
if($result) 
echo "<script>alert(' 操 作成 功 ! ):location='user_group.php':</script>": 
else 


echo "<script>alert(' 系 统 繁忙 ， 请 稍 后 再 试 "):history.go(-1):</script>"; 
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(3) 删除 用 户 组 | 
删除 用 户 组 操作 在 del_group_chk php 文件 中 执行 ， 其 根据 超 链 接 传递 的 ID 值 ， 应 用 | 
delete 语句 完成 数据 的 删除 操作 ， 关 键 代码 如 下 : | 


02 header ( "Content-type: text/html: charset=gb2312" ); /设置 文件 编码 格式 
03 include "../inc/chec.php"; 

04 include"../conn/conn.php": 

05 include "../inc/func.php"; 

06 Sfields=read field($conn."tb group","u group",$ GET[id]): 

07 。/* 删 除 用 户 组 */ 


08 $sqlstr="delete from tb group where id=".$ GET['id]: // 定 义 删除 语句 

09 Sresult=mssql query($sqlstr.$conn): // 执 行 删除 语句 

0。 /本末 末末 则 则 宗家 宁 环 间 宁 宁 浊 守业 环宇 

11 /删除 list 功能 列表 中 相对 应 的 组 */ 

12 Sl sqlstr= "select*from tb list": // 查 询 功 能 表 中 数据 

13 $l result=mssql query($l sqlstr,$conn); // 执 行 查询 语句 

14 while($l rows=mssql fetch row($l result){ /获取 查询 结果 

15 这 $Lrows[] (= "0"){ 

16 谨 生成 用 户 组 列表 */ 

17 Sl_list = explode(",",$] rows[4]): /以 数组 形式 读 取 数据 

18 Snew fields=""; 

19 for($num =0; $num < (count($SL list) -1); Snum++){ ””// 循 环 读 取 数 组 中 数据 

20 if($fields = $1 list[$num]) { 

21 Snew_ficlds = $1 list[$num].",": // 重 新 为 数组 赋值 

22 上 

23 } 

24 S$n_sqlstr = "update tb_list set o_group = ".$Snew_fields." where id =".$1 rows[0]: ,| 
// 执 行 更 新 操作 

25 mssql query($n_sqlstr$conn): 

26 jelse{ 

27 

28 } 

29 

30 /中 中 事 让 束 囊 站 让 下 让 可 训 训 可 下 让 可 可 可 可 事 可 事 相 训 可 来 可 可 可 人 

3 if($result) 

32 echo "<script>alert( 删 除 成 功 ! "):location='"user_group.php':</script>": 

33 else 

34 echo "<script>alert(' 系 统 繁忙 ， 请 稍 后 再 试 '):history.go(-1):</script>"; 

站 > 


6.10.5 ”权限 分 配 


权限 分 配 控制 问 里 办 公 自 动 化 系统 中 每 个 用 户 组 的 访问 权限 。 它 针对 系统 中 的 功能 而 
设 定 ， 指 明 每 个 功能 都 有 哪些 用 户 组 可 以 访问 。 如 图 6.33 所 示 是 用 户 组 A 和 用 户 组 也 的 | 
权限 对 比 。 | 
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图 6.33 用 户 组 权限 对 比 


| 在 pur_assign.php 文件 中 ， 展 示 出 功能 与 用 户 组 的 对 应 关系 ， 其 默认 所 有 的 功能 都 是 
可 访问 的 ， 当 某 些 功能 需要 进行 限制 时 ， 就 为 其 指定 特定 的 用 户 组 。 功 能 与 用 户 组 的 分 配 


| 

| 

| 效果 如 图 6.34 所 示 。 

| 

| 功能 开 政 各 妆 作 
公司 简介 部 门 径 再 总 经 浊 人 改 

| 读 效 评定 部 门 经 更 , 总 经 更 ， 修改 
个 人 议定 9 修改 
意 见 着 ”试用 员工 , 正式 员工 , 用 门 和 更, 总计 理 ，。 修改 
职员 浏览 9 修改 
任务 计划 9 修改 
乍 计 刘 0 修改 
工作 反馈 9 修改 
更 计 划 0 人 
月 计划 9 人 
规章 制 变 节 门 生理 , 总 二 再 ， 修改 
企业 管理 0 修改 
任务 站 站 0 修改 
抽 量 读 效 9 修改 
优秀 员工 9 修改 
企业 公告 9 修改 
活动 实 引 9 修改 
广电 管理 0 修改 
避 太 市 棕 修改 
批示 市 棋 。 意 区 理 , 试用 员工 , 正式 英 工 , 切 门 对 理 ，。 修改 
上 下 班 登记 9 修改 
玫 事 优 全 记 9 修改 
加 班 登记 0 直下 
考 勒 记 示 苇 门 生理, 总 名 各 修改 


| 

| 

| 

| 

| 

| 

| 

图 634 功能 对 应 的 用 户 组 

| 修改 功能 对 应 的 用 户 组 操作 在 modify_assign.php 文件 中 进行 , 最 终 将 修改 数据 提交 到 
| modify_assign_chk.php 文件 中 完成 更 新 操作 。pur_assign.php 的 代码 如 下 : 
| 代码 位 置 ， 配套 资源 \mr\06admin\qxgl\pur assign.php 

01 <?php 
| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

j 


02 session start(); // 开 启 session 支持 

03 include "../inc/chec.php": // 包 含 权 限 检查 文件 

04 include "./conn/conn php": // 包 含 数据 库 链接 文件 
05 $sqlstr = "select idf name.o_group from tb _list":; // 生 成 SQL 语句 

06 ?> 

07 <script src="../js/admin js.js"></script> /引入 JS 脚本 文件 

08 <linkhref="../css/style.css" rel="stylesheet"> /引入 外 部 CSS 样式 文件 
0 

10 <tr><td width="75" height="20" align="center" valign="middle"> 功 能 </td> 
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27 </td></tr></table> 


在 modify_assign.php 文件 中 ， 根 据 超 链接 传递 的 ID 值 ， 查 询 出 指定 功能 数据 ， 六 
创建 form 表单 完成 用 户 组 的 添加 和 删除 操作 ， 其 关键 代码 如 下 : 
代码 位 置 : 配套 资源 \mr\06\admin\qxgl\modify_assign.php 


且 


So | 

11 <td width="75" height="20" align="center" valign="middle"> 开 放 组 </td> | 
Lp <td width="75" height="20" align="center" valign="middle"> 操 作 </td></tr> | 
13 <?php | 
14 /输出 功能 列表 项 六 | 
15 Sresult = mssql_query($sqlstr,$conn): | 
16 while(Srows = mssql fetch row(Sresulb){ | 
17 echo "<tr>": | 
18 for($i = 1;$i < count(Srows); Si++){ |L 
19 echo "<td align=center valign=middle>". $rows[$i]."</td>"; | 
20 | 
21 echo "<td align=center valign=middle><a href='modify assign.php?id=".$rows | 
[0]."> 修 改 </a></td>"; | 
22 echo "</tr>"; | 
23 } | 
和 | 
25 | 
26 </table> | 
! 

! 

! 


01 。 <?php | 
02 header ("Content-type: text/html; charset=gb2312" ); /设置 文件 编码 格式 | 
03 include "inc/chec php": | 
04 include "../conn/conn.php"; | 
05 $sqlstr = "select * from tb_list where id=".$ GET['id]; 
06 $result = mssql query($sqlstr.$conn): 

07 $rows = mssql_fetch_ row(Sresulb; 

08 $sqlstrl = "select id,u_group from tb_group"; 

09 $resultl=mssql query($sqlstrl,$conn); 

10 > 


最 终 在 modify_assign_chk.php 文件 中 ， 获 取 form 表单 提交 的 数据 ， 完 成 功能 对 应 用 | 
户 组 的 更 新 操作 ， 其 代码 如 下 : | 
代码 位 置 ， 配套 资源 \mr\06\admin\qxgl\modify_assign_chk.php 


01 <?php 

02 ”header ("Content-type: text/html; charset=gb2312" ); /设置 文件 编码 格式 

03 include "../inc/chec.php"; 

04 include "../conn/conn.php": 

05 $sqlstr = "update tb list seto group=".$ POST['g list]." where id=".$ POST[id]: 
06 $result = mssql_query($sqlstr,$conn): 

07 这 $resulD) 


08 echo "<script>alert(' 操 作成 功 ! ):location='pur_assign.php':</script>": 
09 else 

10 echo "<script>alert(' 系 统 繁忙 ， 请 稍 后 再 试 '):history.go(-1):</script>"; 
11 > 
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| 6.11 项 目 发 布 


le 1. 搭建 PHP 运行 环境 


由 于 笔者 在 开发 项 目 时 应 用 AppServ 集成 化 安装 包 搭 建 的 PHP 运行 环境 ， 所 以 建议 
读者 也 应 用 AppServ 来 搭建 PHP 运行 环境 。 这 样 可 以 确保 项 目 正常 运行 。 


2. 具体 项 目 发 布 方法 


发 布 本 项 目的 具体 方法 如 下 : 
(1) 将 程序 文件 夹 06 复制 到 AppServ 安装 后 的 www 文件 夹 下 。 -~ 带 格式 的 : 项 目 符号 和 
(2) 在 06 文 件 来 下 ， 查 看 是 否 存在 data 文件 来， 发现 本 程序 应 用 的 是 MS SQL Server 
| 2000 数据 库 。 所 以 在 运行 本 程序 之 前 ， 要 完成 数据 库 的 附加 。 
| (3) 本 系统 应 用 PDO 数据 库 抽象 层 对 MS SQL Server 数据 库 进行 操作 。 所 以 ， 在 运 
| 行 本 程序 之 前 , 要 激活 PDO 模块 。 即 修改 php.ini (如 果 使 用 AppServ 配置 PHP 开发 环境 ， 
| 那么 php.ini 默认 存储 于 本 机 系统 盘 的 windows 文件 夹 下 ) 文 件 , 去掉 extension=php_pdo.dll 
| 和 extension=php_pdo_mssql.dll 加 载 项 前 的 分 号 〈;)， 保 存 后 重新 启动 Apache 服务 器 。 


如 果 用 户 的 PHP 环境 不 支持 mssql 函数 库 中 的 函数 ， 那 么 则 需要 将 AppServ\php5\ 下 的 
| ntwdblib.dll 文件 复制 到 本 机 系统 文件 夹 windows\system32 下 ， 并 重新 启动 Apache 服务 器 。 


| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

| 

(4) 在 本 系统 中 通过 Smarty 完成 前 台 程 序 的 动静 分 离 操作 。 由 于 Smarty 类 库 属于 第 * -~ | 带 格式 的 : 项 目 符号 和 
| 三 方 组 件 ， 在 本 书 的 配套 资源 中 没有 提供 ， 所 以 需要 读者 自行 下 载 ， 并 且 将 下 载 的 libs 文 
| 件 夹 放 置 于 06\system 目录 下 ， 进 而 完成 Smarty 类 库 的 加 载 操 作 。 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 


6.11.2 配置 MS SQL Server 2000 数据 库 


1. MS SQL Server 2000 数据 库 安装 


在 本 系统 中 连接 MS SQL Server 2000 数据 库 ， 前 台 在 0GAsystemsystemine php 文件 中 * -~ 带 格 式 的 :项 目 符号 和 
| 进行 配置 ， 设 置 数据 库 类 型 为 mssql， 服 务 器 为 loaclhost， 用 户 名 为 sa， 密 码 为 裤 。 后 台 

在 admin\conn\conn.php 文件 中 完成 与 数据 库 的 连接 ， 服 务 器 为 localhost， 用 户 名 为 sa， 密 

码 为 空 。 

建议 用 户 安装 MS SQL Server 2000 数据 库 ， 选 择 安装 SQL Server 2000 客户 端 与 服务 

器 端 ， 在 “服务 账户 ”窗口 中 设置 “使 用 本 地 系统 账户 ” 在 “身份 验证 模式 ”对 话 框 中 

选择 “混合 模式 ”。 如 此 ， 当 数据 库 安 装 成 功 后 ， 就 可 以 通过 localhost 服务 器 、 用 户 名 sa、 
| 密码 为 室 ， 与 MS SQL Server 2000 数据 库 进行 连接 。 
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! 
2.，MS SQL Server 2000 数据 库 附 加 | 
| 


MS SQL Server 2000 数据 库 附加 过 程 如 下 : | 

(1) 将 MR\06Wdata 文件 夹 下 扩展 名 为 .MDF 和 .LDF 的 两 个 文件 复制 到 SQL Server | 

2000 安装 路 径 下 的 MSSQL、Data 目录 下 。 | 凶 | 
(2) 打开 SQL Server 2000 中 的 企业 管理 器 ， 然 后 展开 本 地 服务 器 ， 在 “数据 库 ” 选 ， 

项 上 右 击 ， i “所 有 任务 ”/“ 附 加 数据 库 ” 命 令 ， 如 图 6.35 所 示 。 


图 6.35 ”附加 数据 库 | 


(3) 在 弹出 的 “附加 数据 库 ” 对 话 框 中 选择 刚 复制 过 去 的 数据 库 文件 (.MDF 文件 )， 
单 击 “确定 ”按钮 ， 如 图 6.36 所 示 。 


要 附加 数据 库 的 MDF 文件， | 
Evampp \htdocs\TM\ 18\data db_office_Data MDF www | | 
件 名 当前 文件 位 置 < 


中 _ofice_Data MDF 回 Evamppwtdoca\TMN18datavdb_ofice_Dr 
回 Evamppwtdocs\TMN18datavdb_ofice_Lc 


图 6.36 ”选择 所 要 附加 的 数据 库 


(4) 单 击 “确定 ”按钮 ， 将 弹出 如 图 6.37 所 示 的 提示 对 话 框 。 


6.37 系统 提示 
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(5) 单 击 “确定 ”按钮 ， 完 成 附加 数据 库 操作 。 


本 章 小 结 


2 | 本 章 主要 介绍 问 易 办 公 自 动 化 系统 的 实现 过 程 ， 其 中 重点 突出 PHP 与 MS SQL 
Server2000 数据 库 结合 ， 以 及 如 何 通过 PDO 操作 MS SQL Server2000 数据 库 ， 同 时 还 应 用 
Smarty 完成 网 站 的 动静 分 离 。 通 过 本 章 的 学 习 ， 读 者 可 以 了 解 以 下 内 容 。 

(1) 问 易 办 公 自 动 化 系统 的 功能 结构 设计 。 

(2) 数据 库 的 设计 。 

(3) 数据 库 连 接 、 操 作 类 的 封装 。 

(4) Smarty 类 库 的 封装 。 

(5) JavaScript、CSS 样式 的 应 用 。 

(6) 自 定义 函数 的 妙用 。 


| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
】 
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( PHP+MySQL 5.0 实现 ) 
自学 视频 、 源 程序 : 配套 资源 MnNA 


告别 


一 段 青 春风 月， 毕业 设计 成 为 大 学 学 习 生 活 结 束 的 圆满 句号 。 它 是 学 


生 对 在 大 学 中 所 学 知识 综合 运用 的 体现 ， 也 是 培养 学 生 能 力 的 重要 组 成 部 分 。 
本 章 以 图 书馆 管理 系统 为 基础 ， 详 细 介 绍 如 何 合理 、 有 了 序 地 援 写 一 份 完整 的 毕 
业 设 计 论 文 。 


学 习 摘 要 : 


ed 


于 于 于 于 至 


开题 报告 的 填写 

封面 设计 原则 
目录 的 编排 方法 

毕业 设计 的 中 /英文 摘要 范例 
毕业 设计 整体 结构 

毕业 设计 正文 书写 范例 
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可 
7.1 设计 说 明 

7.1.1 毕业 设计 (论文 ) 主要 内 容 国会 4 

毕业 设计 是 一 份 由 即将 毕业 的 学 生 提供 的 研究 性 报告 ， 该 报告 是 在 指定 教师 的 指导 其 


下 ， 进 行 初步 科学 研究 所 取得 成 果 的 科学 表述 ， 也 可 以 是 一 篇 在 教师 的 指导 下 集体 或 个 人 | 

阅读 文献 的 总 结 。 一 份 完整 的 毕业 设计 至 少 应 包括 以 下 内 容 。 

加 开题 报告 开题 报告 一 般 需 要 学 生 结合 自身 信息 来 填写 所 选 毕 业 设计 (论文 ) 题 | 

目 、 个 人 信息 、 选 题 意义 和 内 容 等 信息 ， 是 一 篇 综合 性 的 报告 。 

加 中 /英文 文献 与 所 选 毕业 设计 技术 相关 的 科技 类 文字 或 说 明 。 | 

回 ”毕业 设计 封面 (可 选 》: 主要 包括 具有 概括 性 文字 的 选 文 标题 以 及 学 生 姓名 、 指 | 

导 教师 等 信息 。 

名 中 /英文 摘要 设计 《论文 ) 的 中 文摘 要 一 般 为 200~300 字 ， 摘 要 是 一 篇 具有 独 | 

立 性 和 完整 性 的 短文 。 设 计 论 文 ) 英文 摘要 的 内 容 与 中 文摘 要 相同 。 

回 设计 (论文 ) 目录 目录 应 独立 成 页 ， 包 括 设计 论文) 中 全 部 章 、 节 的 标题 及 | 

页 码 ，。 

回 设计 (论文) 正文， 正文 是 毕业 设计 论文 ) 的 主体 ， 着 重 反 映 研 究 工作 范畴 和 | 

研究 方法 ， 并 将 调查 、 研 究 中 所 获得 的 材料 和 数据 进行 加 工整 理 和 分 析 研 究 ， 提 | 

出 论点 。 
附录 〈 可 选 ) :一 般 由 论文 作者 提供 与 论文 内 容 相关 的 图 片 、 程 序 代码 等 信息 。 

参考 文献 ， 毕 业 设计 作者 在 撰写 设计 《论文 ) 时 所 参考 的 相关 书籍 、 报 纸 、 杂 志 | 

等 文献 作品 。 

致谢 ， 对 指导 教师 和 给 予 指导 或 协助 完成 设计 《论文 ) 工作 的 组 织 和 个 人 表示 感 | 

谢 。 内 容 应 简洁 明了 、 实 事 求 是 ， 避 免 落 入 俗套 。 


7.1.2 ”毕业 设计 (论文) 要求 


图 书馆 管理 系统 毕业 设计 论文) 的 要 求 是 ， 通 过 对 图 书馆 的 实际 考察 、 分 析 ， 并 结 | 

合 图 书馆 的 要 求 以 及 实际 的 市 场 调查 ， 综 合 图 书馆 发 展 的 需要 ， 以 B/S 模式 为 基础 ， 独 立 | 
开发 设计 图 书馆 管理 系统 ， 并 撰写 毕业 设计 〈 论 文 )。 | 
毕业 设计 《论文 ) 各 部 分 的 一 般 顺 序 为 中 英文 题目 、 中 文摘 要 、 英 文摘 要 、 目 录 、 正 | 
文 、 参 考 文献 、 致 谢 、 附 录 。 主 要 要 求 如 下 : | 
回 “正文 内 容 包括 绪论 引言) 、 主 体 部 分 和 结论 3 个 重要 部 分 。 正 文 要 求 论点 正确 、| 
推理 严谨 、 数 据 可 靠 、 文 字 精 练 、 条 理 分 明 。 


网 网 


风 


正文 章节 序号 : 第 一 章 、1.1、1.1.1; 第 二 章 、2.1、2.1.1.……。 
正文 字数 要 求 : 10 000~15 000 字 。 | 
参考 文献 说 明 : 列 出 引用 的 主要 文献 。 为 了 反映 文稿 的 科学 依据 ， 尊 重 他 人 的 研 | 
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， 
| 究 成 果 以 及 向 读者 提供 有 关 信 息 的 出 处 ， 正 文中 应 按 顺序 在 引用 参考 文献 处 的 文 
| 字 右上 角 用 “[” 标 明 ，“ 口 ”中 的 序号 应 与 参考 文献 列表 中 序号 一 致 。 

| ”加 参考 文献 数量 不 少 于 4 篇 ， 其 中 外 文 参 考 文献 不 少 于 1 篇 。 

| ”加 参考 文献 主要 包括 连续 出 版 物 〈 期 刊 ) 、 专 著 、 专 利文 献 、 国 际 和 国家 标准 以 及 
| 报纸 文章 等 。 

加 ”格式 要 求 : 根据 相应 规定 更 改 毕业 设计 〈 论 文 ) 格式。 


7.2 填写 开题 报告 


开题 报告 是 由 毕业 论文 作者 根据 论文 题目 填写 的 报告 说 明 ， 其 大 体格 式 和 主要 内 容 如 
| 下 所 示 。 


XX 师范 大 学 本 科 毕 业 论文 〈 设 计 ) 开题 报告 


基于 PHP 的 图 书馆 管理 系统 设计 
计算 机 科学 与 技术 
XXX (职称 ) 


本 选 题 的 意义 及 在 国内 外 的 发 展 状况 : 

随 着 网 络 技术 的 高 速 发 展 和 计算 机 应 用 的 普及 ， 利 用 计算 机 对 图 书馆 的 日 常 工作 进行 管理 势 在 必 
行 。 虽 然 目前 很 多 大 型 图 书馆 已 经 有 一 整套 比较 完善 的 管理 系统 ， 但 是 在 一 些 中 小 型 图 书馆 中 ， 大 部 
分 工作 仍 需 由 手工 完成 ， 工 作 效 率 较 低 ， 管 理 员 不 能 及 时 了 解 图 书馆 内 各 类 图 书 的 借阅 情况 ， 读 者 需 
要 的 图 书 难 以 在 短 时 间 内 找到 ， 不 便于 动态 、 及 时 地 调整 图 书 结构 。 为 了 更 好 地 适应 当前 读者 的 借阅 
需求 、 解 决 手工 管理 中 存在 的 许多 浆 端 ， 越 来 越 多 的 中 小 型 图 书馆 正在 逐步 向 计算 机 信息 化 管理 转变 。 

研究 内 容 : 

基于 PHP 的 图 书馆 管理 系统 原理 设计 。 

基于 PHP 的 图 书馆 管理 系统 程序 设计 。 

前 台 页 面 设计 和 软件 部 分 调试 。 
研究 方法 、 手 段 及 步 又 : 
系统 流程 设计 : 针对 本 设计 要 求 并 配合 查阅 网 上 资料 ， 设 计 整 个 实现 流程 。 
原理 图 绘制 : 应 用 绘图 软件 绘 出 原理 图 。 
前 台 页 面 设 计 : 应 用 Dreamweaver 软件 ， 结 合 JavaScript 语言 设计 前 台 界 面 。 
后 台 程序 编写 : 根据 原理 图 要 求 编程 。 
前 台 页 面 和 后 台 程 序 的 联合 调试 : 测试 已 经 完成 的 程序 ， 修 正 逻 辑 问题 及 语法 错误 。 
参考 文献 : 
[1] 邹 天 思 ， 孙 胶 . PHP 从 入 门 到 精通 [M]. 北 京 : 清华 大 学 出 版 社 ，2008. 
[2] 潘 凯 华 ， 邹 天 思 . PHP 开发 实战 宝典 [MI]. 北 京 : 清华 大 学 出 版 社 ，2010. 
[3] 邹 天 思 ， 潘 凯 华 ， 刘 中 华 . PHP 网 络 编程 自学 手册 [MI] .北京 : 人 民 邮 电 出 版 社 ，2008. 
[4] 〈 美 ) Vasani 著 . MySQL 完全 手册 [M]. 徐 小 青 ， 路 晓 村 等 译 . 北京 : 电子 工业 出 版 社 ，2004. 
[5] 潘 凯 华 等 . PHP 项 目 开发 案例 全 程 实录 [M]. 2 版 . 北京 : 清华 大 学 出 版 社 ，2011. 
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7.3 封面 设计 


毕业 设计 的 封面 要 遵行 简洁 、 大 方 、 得 体 的 设计 思想 ， 内 容 上 清晰 、 明 了 ， 文 字 有 概 | f 
括 性 。 毕 业 设 计 的 题目 不 宜 超过 25 个 字 ， 另 外 ， 标 题 中 尽量 不 要 用 英文 缩写 词 。 优 秀 的 | 对 
毕业 设计 封面 不 但 可 以 给 审阅 教师 耳目 一 新 的 感觉 ， 也 可 以 向 答辩 委员 会 清晰 地 展示 出 自 
己 的 论文 选 题 。 大 多 数学 校对 毕业 设计 的 封面 没有 限制 性 要 求 ， 所 以 ， 有 具体 的 封面 设计 还 
需要 读者 根据 自身 的 实际 情况 而 定 , 这 里 只 给 出 最 基本 的 封面 样式 , 供 读者 参考 , 如 图 7.1 | 
所 示 。 | 


X X 师 范 大 学 
毕业 设计 


基于 PHP 的 图 书馆 管理 系统 实现 


The Design and Implementation of 
Library Management System Based 
on PHP 


系 ” 别 : 信息 工程 
专业 和 名称: 计算 机 科学 与 技术 
学 生 姓名 : 李 唱 

指导 教师 : 潘 攀 ( 恒 教 授 ) 
完成 时 间 : 2011 年 6 月 


图 7.1 毕业 设计 封面 
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7.4 书写 摘要 


毕业 设计 的 第 一 页 和 第 二 页 分 别 为 中 文摘 要 与 英文 摘要 。 摘 要 书写 必须 完全 遵循 英汉 
对 应 的 关系 ， 即 英文 摘要 译 成 的 中 文 要 与 中 文摘 要 内 容 相 同 。 男 外 ， 摘 要 是 一 篇 具有 独立 
性 和 完整 性 的 短文 ， 文 字 要 精炼 ， 应 扼要 叙述 本 设计 的 研究 目的 和 内 容 、 主 要 特点 和 成 果 
及 结论 性 意见 。 摘 要 中 不 宜 使 用 公式 、 图 表 ， 不 标注 引用 文献 编号 ， 避 免 将 摘要 写成 目录 


| 式 的 内 容 介绍 。 为 了 便于 文献 检索 ， 应 在 摘要 下 方 男 起 一 行 注 明 本 文 的 关键 词 。 在 英文 摘 
| 要 中 同样 需要 提供 对 应 的 英文 关键 词 。 关 键 词 应 采用 能 覆盖 设计 论文) 主要 内 容 的 通 
| 用 技术 词 条 (参照 相应 的 技术 术语 标准 )， 一 般 为 3 一 5 个 ， 并 按 词 条 的 外 延 层次 由 大 
| 到 小 进行 排列 。 下 面 分 别 向 读者 展示 图 书馆 管理 系统 毕业 设计 《论文 ) 的 中 英文 摘要 。 


1， 中 文摘 要 
随 着 人 类 社会 的 发 展 ， 人 类 对 知识 的 需求 也 不 断 地 增长 。 在 这 种 形势 下 ， 书 籍 就 渐渐 


地 成 为 人 们 获取 并 增长 知识 的 主要 途径 ， 而 图 书馆 就 自然 而 然 地 在 人 们 的 生活 中 占据 了 一 
| 定 的 地 位 ， 如 何 科学 地 管理 图 书馆 不 但 关系 到 读者 求知 的 方便 程度 ， 也 关系 到 图 书馆 的 发 


展 ， 因 此 ,开发 一 套 完 善 的 图 书馆 管理 系统 就 必 不 可 少 了 。 本 文 介 绍 了 在 PHP 环境 下 采用 
“ 自 上 而 下 地 总 体 规划 ， 自 下 而 上 地 应 用 开发 ”的 策略 开发 本 系统 的 详细 过 程 ， 提 出 实现 
图 书馆 信息 管理 、 资 源 共享 的 基本 目标 ， 从 而 推动 迈 向 数字 化 图 书馆 的 步伐 ， 并 半 述 系统 
结构 设计 和 功能 设计 ， 从 图 书 的 入 库 登 记 到 查询 浏览 ， 从 借 书证 发 放 到 图 书 的 借阅 ， 形 成 
了 一 个 整体 自动 化 管理 模式 ， 从 软件 工程 的 角度 进行 了 科学 而 严谨 的 阐述 。 

关键 词 : 图 书 管理 借阅 浏览 PHP 

2. 英文 摘要 ( Abstract ) 


With the development of society, mankind need more knowledge also constantly increase. 
Under this situation, book gradually become the main path to obtain the knowledge of life, and 
library naturally occupied in people certainly position, how science ground the management 
library not only relate to the convenient degree that the reader beg to know, but also relate to the 
library that strategy of development. Therefore, develop the management System of a perfect 
library can’t little. This text introduced under the PHP, the environment adoption “from top to 
bottom total programming, from the detailed process that bottom but up applied development” 
develop this system, from the step that but the push head into the arithmetic figure of the library, 
and shows the system construction design and function design, from the books of store in 
warehouse to register the search to view, books that issue from library card to angle of borrow, 
become the whole automation management mode, and proceeds careful explain from the 
software engineering science. 


Keywords: Library Borrow Searchtoview PHP 
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7.5 编排 目录 
目录 是 整个 毕业 设计 内 容 的 索引 ， 其 作用 主要 为 审阅 人 员 展 示 毕 业 设 计 的 整体 架构 和 


标题 内 容 ， 毕 业 设计 目录 一 般 应 独立 成 页 ， 主 要 包括 设计 中 全 部 章 、 节 的 标题 及 页 码 ( 包 | 国 
括 参考 文献 、 致 谢 )。 下 面 给 出 目录 的 具体 样式 。 


1.1 本 课题 的 开发 背景 及 意义 - 
1.1.1 设计 的 背景 


ETI2 开发 意义 二 | 
a 
设计 和 如 结构 rene 入 

第 2 章 开发 工具 及 相关 技术 - -4 
pA 2 4 

i Danner 4 

2.1.2 Zend Development Environment (ZDE) 简介 4 

5 了 5 
0 

2.2.1 PHP5.0… 6 

2.2.2 ”Apache 下 

2.23 MySQL 下 本 全 和 下 下 下 下 下 和 和 下 下 在 人 下 下 和 本 生生， 和 


2.2.4 ”运行 环境 的 搭建 


到 二 


2.3.2 JavaScript 语 襄 二 
3 SS 样式 表 Sa 9 
24 B/S 结构 简介 NO 10 


第 3 章 需求 分 析 …… 
3.1 可行 性 分 析 … 


3.1.1 系统 的 必要 性 - -11 
3.1.2 系统 的 可 行 性 11 
3.2 ”系统 需求 12 
3.3 ”功能 需求 … 


34 ”性 能 要 求 13 


Re 0 L_ 


人 Eap 项 目 业 全 分析 


2 2 14 
th 到 
| 中 2 过 人 筑 实体 BR 国语 15 
ff | 4.3 系统 数据 表 设 计 … 
~ | 4.3.1 用 户 表 设计 一 15 
43.2 图书 系 统 表 设 计 二 ee 16 
| 4.3.3 ”管理 员 表 设计 E 
9 村 书 借 阅 家 设 陡 ne 18 
第 5 章 系统 设计 PPO ON ON 区 2 E 9 二 19 
5.1 系统 实现 关系 图 … 
5.2 系统 功能 模块 设计 … 
5.2.1 系统 的 功能 模块 … 
5.2.2 系统 的 模块 特 
第 6 章 系统 功能 实现 … 


6.1 管理 员 模块 设计 ;23 
6.1.1 系统 登录 23 
6.1.2 查看 管理 员 于 


6.1.3 ”添加 及 删除 管理 员 -… 
6.1.4 设置 管理 员 权限 ………………… 
6&3 图 书 档案 管理 模块 没 计 eased 30 
6.2.1 查看 图 书信 息 列表 
6.2.2 ”添加 图 书信 息 
6.2.3 ”修改 图 书信 息 
6.3 ”图 书 借 还 模块 设计 
6.3.1 图书 借阅 
6.3.2 图书 续 借 
6.3.3 ”图 书 归还 


附录 A 主 程 序 BR 41 


| 说明; 
| “以 上 毕业 设计 目录 中 涉及 的 内 容 和 页 码 ， 请 读者 根据 实际 情况 制定 ， 这 里 仅 为 读者 提 
| 供 一 个 参考 。 
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$9 
7.6 绪论 


绪论 主要 用 于 说 明 选 题 背景 、 目 的 及 意义 ， 国 内 外 现状 和 应 解决 的 主要 问题 。 
7.6.1 本 课题 的 开发 背景 及 意义 


根据 对 各 学 校 图 书馆 的 调查 可 知 , 随 着 学 校 图 书馆 规模 的 不 断 扩大 , 经 营 的 图 书 品种 、| 
数量 也 逐渐 增多 。 在 学 校 图 书馆 不 断 发 展 的 同时 ， 校 图 书馆 常年 采用 的 传统 的 人 工 管理 方 | 
式 暴露 出 了 一 些 问 题 。 例 如 ， 查 找 读者 借阅 的 某 一 本 图 书 的 具体 摆 放 位 置 ， 需 要 靠 人 工 记 | 
忆 在 书 海中 苦 苦 查找 ， 由 于 图 书 储存 量 大， 很 难 准确 定位 图 书 的 具体 位 置 ， 因 此 ， 每 天 都 | 
要 浪费 大 量 时 间 资 源 。 学 校 图 书馆 为 提高 工作 效率 ， 同 时 摆脱 图 书 管理 人 员 在 工作 中 出 现 | 
的 种 种 次 端 ， 现 需要 委托 某 单位 开发 一 个 学 校 图 书馆 管理 系统 。 | 


7.6.2 ”课题 研究 内 容 


本 设计 主要 应 用 PHP 编程 、Web 开发 以 及 MySQL 数据 库 连接 等 相关 知识 。 需 要 熟练 | 
掌握 动态 网 页 开发 技术 ， 将 所 学 的 知识 用 于 实际 生活 中 ， 并 且 在 实际 的 生活 中 发 挥 其 主要 | 
功能 并 获得 效益 ， 本 设计 内 容 包 括 以 下 功能 模块 。 | 
回 管理 员 管理 模块 : 主要 包括 管理 员 登 录 、 查 看 管理 员 列 表 、 添 加 管理 员 信息 、 管 | 

理 员 权 限 设置 、 删 除 管 理 员 和 更 改口 令 等 功能 。 | 

加 ”图 书 档案 管理 模块 ， 主 要 包括 查看 图 书 列表 、 添 加 图 书信 息 、 修 改 图 书信 息 、 删 | 

除 图 书信 息 和 查看 图 书 详细 信息 等 功能 。 | 

回 图 书 借 还 模块 : 主要 包括 图 书 借阅 、 图 书 续 借 、 图 书 归还 、 图 书 档案 查询 、 图 书 | 
借阅 查询 和 借阅 到 期 提醒 等 功能 。 | 


说 明 : | 
这 里 仅 列 出 主要 的 功能 模块 即 可 。 | 


7.6.3 设计 组 织 结构 


本 毕业 设计 的 主体 主要 分 为 6 大 部 分 。 

加 第 1 部 分 : 即 绪论 部 分 ， 主 要 介绍 毕业 设计 论文) 的 开发 背景 及 意义 、 研 究 内 | 
容 、 组 织 结构 等 内 容 。 
第 2 部 分 ， 主要 介绍 本 毕业 设计 中 所 用 到 的 开发 软件 、 运 行 环境 以 及 开发 过 程 所 | 
需要 的 结构 体系 等 要 素 。 

第 3 部 分 : 介绍 系统 的 可 行 性 分 析 以 及 功能 需求 等 内 容 。 

第 4 部分， 介绍 数据 库 的 基本 数据 表 结构 设计 。 

第 5 部分， 根据 需求 分 析 整 个 系统 的 架构 并 陈列 主要 功能 模块 。 

第 6 部 分 ， 详 细 讲解 各 功能 模块 的 实现 过 程 和 运行 结果 。 
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7.7 开发 工具 及 相关 技术 


7.7.1 常用 开发 工具 


1. Dreamweaver 简介 


Dreamweaver 是 美国 Adobe 公司 开发 的 集 网 页 制作 和 网 站 管理 于 一 体 的 所 见 即 所 得 网 
页 编辑 器 ， 它 是 第 一 套 针对 专业 网 页 设计 师 特 别 发 展 的 视觉 化 网 页 开发 工具 ， 利 用 它 可 以 
轻而易举 地 制作 出 跨越 平台 限制 和 浏览 器 限制 的 充满 动感 的 网 页 。 

Dreamweaver、Flash 以 及 在 Dreamweaver 之 后 推出 的 针对 专业 网 页 图 像 设计 的 Fireworks， 
被 Adobe 公司 称 为 DREAMTEAM ( 梦 之 队 )， 足 见 市 场 的 反响 和 Adobe 公司 对 它们 的 自信 。 
说 到 Dreamweaver， 读 者 应 该 了 解 一 下 网 页 编辑 器 的 发 展 过 程 。 随 着 互联 网 (Intemet) 的 家 
喻 户 晓 、HTML 技术 的 不 断 发 展 和 完善 ， 产 生 了 众多 网 页 编辑 器 ， 根 据 网 页 编辑 器 的 基本 性 
质 不 同 ， 可 以 将 其 分 为 所 见 即 所 得 网 页 编辑 器 和 非 所 见 即 所 得 网 页 编辑 器 〈 即 原始 代码 编辑 
器 )， 二 者 各 有 千秋 。 所 见 即 所 得 网 页 编辑 器 的 优点 是 直观 、 使 用 方便 、 容 易 上 手 。 

Dreamweaver 可 以 用 最 快捷 的 方式 将 Fireworks、FreeHand 或 Photoshop 等 档案 移 至 网 
页 上 。 使 用 检 色 吸管 工具 选择 屏幕 上 的 颜色 可 设 定 最 接近 的 网 页 安全 色 。 对 于 选单 、 快 捷 
键 与 格式 控制 , 都 只 要 一 个 简单 的 步骤 便 可 完成 。 Dreamweaver 能 与 用 户 喜 爱 的 设计 工具 ， 
如 Playback Flash、Shockwave 和 外 挂 模 组 等 搭配 ， 不 需 离开 Dreamweaver 便 可 完成 ， 整体 
运用 流程 自然 顺 幅 。 除 此 之 外 ， 只 要 单 击 便 可 使 Dreamweaver 自动 开启 Firework 或 
Photoshop 来 进行 编辑 与 设 定 文件 的 最 佳 化 。 


2. Zend Development Environment ( ZDE ) 简介 


Zend Development Environment 是 在 Linux 下 面 唯一 一 个 PHP 的 集成 开发 调试 环境 ， 
当然 它 也 有 Windows 版 本 。 和 其 他 IDE 不 同 ，ZDE 是 用 Java 编写 的 ， 这 不 光 意 味 着 多 平 
台 性 ， 同 时 意味 着 给 用 户 在 使 用 上 带 来 很 多 不 便 。 

ZDE 提供 的 功能 是 最 齐全 的 ， 而 且 可 以 和 ZEND 等 其 他 PHP 开发 工具 无 颖 结合 ， 成 
为 一 套 强大 的 PHP 开发 环境 ， 而 且 ZDE 的 调试 环境 是 建 在 ZDE 自身 程序 里 面 的 ， 而 不 像 
其 他 IDE， 是 通过 PHP Debuger 来 实现 的 。 

ZDE 的 特征 为 语法 加 亮 、 完 整齐 全 的 函数 补 全 和 帮助 〈 但 只 针对 PHP 内 建 函数 ， 对 
自 定义 函数 无 效 )、 工 程 管理 ， 还 有 ZDE 独 有 的 PHP 代码 整理 、PHPini 可 视 化 编辑 和 媒 
套 标 示 功 能 ， 使 用 后 者 查看 结构 复杂 的 程序 十 分 方便 ， 再 不 用 去 数 密密麻麻 的 “{}” 号 了 。 

提供 的 Debug 功能 包括 breakpoints、stack、watches、variables、output buffer 以 及 所 
有 该 有 的 跟踪 方式 。 

3. PHPED 简介 

PHPED 的 综合 性 能 是 最 好 的 ， 启 动 速度 快 ， 提 供 的 功能 也 最 多 ， 包 括 语 法 加 亮 、 函 
数 补 全 、 工 程 管理 、 代 码 模版 、 自 动 代码 补 全 、 可 视 化 的 数据 库 管理 ， 内 置 DAV、CVS、 
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FTP、WEBSERVER、DEBUGGER、]JS 代码 列表 和 常见 HTML 标签 集 ， 另 外 PHPED 还 支 
持 插件 技术 。 | 

PHPED 安装 版 还 附带 了 PHP、MySQL 的 手册 英文 版 )。 值 得 一 提 的 是 PHPED 的 调 
试 功能 ， 虽 然 ZDE 有 它 所 有 的 调试 功能 ， 但 是 PHPED 更 方便 ， 如 调试 时 将 鼠标 光标 放 在 | 
变量 上 就 可 以 直接 看 到 变量 的 值 ， 而 且 调 试 窗口 的 分 布 较 细致 和 合理 ， 支 持 外 部 脚本 调 | 
试 ，ZDE 虽然 也 能 实现 ， 但 设置 起 来 比较 麻烦 。 


7.7.2 ”运行 环境 
1. PHP 5.0 


2004 年 7 月 13 日 , PHP 5.0 发 布 。 该 版 本 以 Zend 引擎 I[ 为 引擎 ， 并且 加 入 了 新 功能 ，| 
如 PHP Data Objects (PDO)。 现 在 PHP 5.0 版 本 强化 了 更 多 的 功能 。 首 先 ， 完 全 实现 面向 | 
对 象 ， 提 供 名 为 PHP 兼容 模式 的 功能 。 其 次 是 XML 功能 ，PHP 5.0 版 本 支持 直观 地 访问 | 
XML 数据 、 名 为 SimpleXML 的 XML 处 理 界面 。 同 时 还 强化 了 XML Web 服务 支持 ， 而 且 | 
标准 支持 SOAP 扩展 模块 。 数 据 库 方面 ，PHP 新 版 本 提供 由 在 访问 MySOL 的 新 界面 一 一 | 
MySQL。 除 此 前 的 界面 外 ， 还 可 以 使 用 面向 对 象 界面 和 预 处 理 语句 (Prepared Statement) | 
等 MySQL 的 新 功能 。 另 外 ，PHP 5.0 上 还 捆绑 有 小 容量 RDBMS-SQLite。 

(1) 新 的 对 象 模式 (New Object Mode) | 

PHP 5.0 中 的 对 象 已 经 进行 了 较 系统 、 全 面 的 调整 ， 现 在 类 似 于 Java。 下 面 着 重 讲述 | 
PHP5.0 中 新 的 对 象 模式 ， 并 举例 进行 说 明 。 | 

@ 构造 函数 和 析 构 函数 | 
在 PHP 4 中 ， 当 函数 与 对 象 同名 时 ， 该 函数 将 成 为 该 对 象 的 构造 函数 ， 并 没有 析 构 函 | 
数 的 概念 。 | 

在 PHP 5.0 中 ， 构 造 函 数 被 统一 命名 为 _construct， 并 且 引 入 了 析 构 函数 的 概念 ， 被 | 
统一 命名 为 _ destruct。 | 

@ 对 象 的 引用 | 

在 PHP 4 中 ， 传 递 变量 给 一 个 函数 或 方法 ， 实 际 是 把 该 变量 复制 一 次 ， 也 就 意味 着 用 | 
户 传 给 函数 或 方法 的 是 这 个 变量 的 一 个 副本 ， 除 非 用 户 使 用 了 引用 符号 “&” 来 声明 是 要 | 
作 一 个 引用 ， 而 不 是 一 次 复制 。 在 PHP 5.0 中 ， 对 象 总 是 以 引用 的 形式 存在 的 ， 对 象 中 的 | 
赋值 操作 同样 也 都 是 一 个 引用 操作 。 | 

@ 对 象 的 克隆 

当 一 个 对 象 始终 以 引用 的 形式 来 被 调用 时 ， 若 想得到 该 对 象 的 一 个 副本 ， 该 怎么 办 ? 
PHP 5.0 提供 了 一 个 新 的 功能 ， 就 是 对 象 的 克隆 ， 语 法 为 _clone。 

@ 对 象 中 的 私有 、 公 共 及 保护 模式 | 

PHP 4 中 ， 一 个 对 象 的 所 有 方法 和 变量 都 是 公共 的 ， 这 意味 着 用 户 可 以 在 一 个 对 象 的 | 
外 部 操作 其 中 的 任意 一 个 变量 和 方法 。PHP 5.0 引入 了 3 种 新 的 用 来 控制 这 种 存 取 权限 的 | 
模式 ， 分 别 是 公共 的 《Public)、 受 保护 的 《Protected) 及 私有 的 (Private)。 | 

加 ”公共 模式 (Public〉: 允许 在 对 象 外 部 进行 操作 控制 。 
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到 
私有 模式 〈Private) : 只 允许 本 对 象 内 的 方法 对 其 进行 操作 控制 。 
受 保护 模式 〈Protected) : 允许 本 对 象 及 其 父 对 象 对 其 进行 操作 控制 。 
@@ 接口 (Interfaces) 
PHP 4 中 的 对 象 支持 继承 ， 要 使 一 个 对 象 成 为 另 一 个 对 象 的 派生 类 ， 用 户 需 要 使 用 类 
似 class foo extends parent 的 代码 来 控制 。 PHP 4 和 PHP 5.0 中 , 一 个 对 象 都 仅 能 继承 一 次 ， 
多 重 继承 是 不 被 支持 的 。 不 过 ， 在 PHP 5.0 中 产生 了 一 个 新 的 名 词 一 一 接口 。 接 口 是 一 个 
没有 具体 处 理 代码 的 特殊 对 象 ， 它 仅仅 定义 了 一 些 方 法 的 名 称 及 参数 ， 此 后 的 对 象 就 可 以 
方便 地 使 用 implement 关键 字 把 需要 的 接口 整合 起 来 ， 然 后 再 加 入 具体 的 执行 代码 。 
抽象 类 
抽象 类 不 能 被 实例 化 ， 与 其 他 类 一 样 ， 允 许 定义 变量 及 方法 。 
抽象 类 同样 可 以 定义 一 个 抽象 的 方法 ， 抽 象 类 的 方法 不 会 被 执行 ， 不 过 将 有 可 能 会 在 
其 派生 类 中 执行 。 
@ _call0 方 法 
PHP 5.0 的 对 象 新 增 了 一 个 专用 方法 _call0, 该 方法 用 来 监视 一 个 对 象 中 的 其 他 方法 。 
如 果 用 户 试 图 调用 一 个 对 象 中 不 存在 的 方法 ，_call0 方 法 将 会 被 自动 调用 。 
_set 和 ”get 方法 
_ set 和 ”get 方法 可 以 用 来 捕获 一 个 对 象 中 不 存在 的 变量 和 方法 。 
在 PHP5.0 中 ， 用 户 可 以 在 对 象 的 方法 中 指明 其 参数 必须 为 另 一 个 对 象 的 实例 。 
静态 成 员 和 吏 态 方法 在 面 象 对 象 编程 的 术语 中 被 称 作 类 方法 (class methods) 和 类 变 
量 (class variables)。 
(2) 异常 处 理 〈Exceptions) 
异常 处 理 是 公认 的 处 理 程 序 错误 的 理想 方法 ， 在 Java 及 C 中 都 有 这 个 概念 ， 令 人 欣 
喜 的 是 ， 在 PHP 5.0 中 已 经 加 入 了 这 方面 的 应 用 。 用 户 可 以 尝试 使 用 try 和 catch 语句 来 控 
制程 序 的 错误 。 当 有 错误 发 生 时 ， 代 码 会 把 错误 交 给 catch 子 句 来 处 理 。 在 catch 子 句 中 ， 
用 户 需要 指明 要 把 错误 交 给 某 个 对 象 处 理 ， 这 样 做 可 以 使 代码 结构 看 起 来 更 清晰 ， 因 为 现 
在 调试 者 可 以 把 所 有 的 错误 信息 交 给 一 个 对 象 来 处 理 。 
(3) 自 定义 错误 处 理 
用 户 可 以 很 方便 地 用 自 定 义 的 处 理 错误 的 代码 来 控制 程序 中 的 意外 。 用 户 仅 需 从 异常 
类 中 派生 出 一 个 自己 的 错误 控制 类 ， 在 其 错误 控制 类 中 ， 需 要 有 一 个 构造 函数 和 一 个 
getMessage() 方 法 。 
(4) 名 称 空间 (Namespace) 
名 称 空 间 对 类 的 分 组 或 函数 分 组 很 有 用 。 它 可 以 把 一 些 相关 的 类 或 函数 组 合 到 一 起 ， 
方便 以 后 调用 。 例 如 : 
01 <?php 


02 namespace Math 
03 { 
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04 class Complex 

058 7 

06 1...code... 

07 function _constructO 


09 print("hey"); 

100 3 

中 

1 

13 $m=newMath::Complex(); 

14 ?> | 

在 实际 运用 中 ， 用 户 可 能 会 需要 声明 两 个 或 多 个 名 称 一 样 的 对 象 来 做 不 同 的 事情 ， 那 | 

么 就 可 以 把 它们 分 别 放 到 不 同 的 名 称 空间 中 去 但 接口 是 要 相同 的 )。 | 


注意 : | 
所 有 相关 工具 和 软件 的 资料 ， 读 者 可 以 通过 查阅 相关 书籍 或 直接 访问 互联 网 获取 。 | 


2. Apache 


Apache 是 世界 使 用 排名 第 一 的 Web 服务 器 软件 。 由 于 其 跨 平台 性 和 安全 性 ， 它 可 以 | 
运行 在 几乎 所 有 广泛 使 用 的 计算 机 平台 上 ， 是 最 流行 的 Web 服务 器 端 软 件 之 一 。 | 

Apache 源 于 NCSAhttpd 服务 器 ， 经 过 多 次 修改 ， 成 为 世界 上 最 流行 的 Web 服务 器 软 | 
件 之 一 。Apache 取 自 a patchy server 的 读音 ， 意 思 是 充满 补丁 的 服务 器 ， 因 为 它 是 自由 软 | 
件 ， 所 以 不 断 有 人 来 为 它 开发 新 的 功能 、 新 的 特性 ， 修 改 原 来 的 缺陷 。Apache 的 特点 是 简 | 
单 、 速 度 快 、 性 能 稳定 ， 并 可 作为 代理 服务 器 来 使 用 。 | 

Apache 原本 只 用 于 小 型 或 试验 Internet 网 络 ， 后 来 逐步 扩充 到 各 种 UNIX 系统 中 ， 尤 | 
其 对 Linux 的 支持 相当 完美 。Apache 有 多 种 产品 ， 可 以 支持 SSL 技术 ， 支 持 多 个 虚拟 主 | 
机 。Apache 是 以 进程 为 基础 的 结构 ， 进 程 要 比 线程 消耗 更 多 的 系统 开支 ,不 太 适 合 于 多 处 | 
理 器 环境 ， 因 此 ， 在 一 个 Apache Web 站 点 扩容 时 ， 通 常 是 增加 服务 器 或 扩充 群集 节点 而 | 
不 是 增加 处 理 器 。 到 目前 为 止 ，Apache 仍然 是 世界 上 使 用 最 多 的 Web 服务 器 ， 市 场 占 有 | 
率 达 60% 左 右 。 世 界 上 很 多 著名 的 网 站 ,如 Amazon、Yahoo!、W3 Consortium、Financial Times | 
等 都 是 Apache 的 产物 ， 其 成 功 之 处 主要 在 于 它 的 源 代码 开放 、 有 一 支 开 放 的 开发 队伍 、 
支持 跨 平 台 的 应 用 可 以 运行 在 儿 乎 所 有 的 UNIX、Windows、Linux 系统 平台 上 ) 以 及 具 | 
有 可 移植 性 等 方面 。 | 

Apache 的 诞生 极 富 戏剧 性 。 当 NCSA WWW 服务 器 项 目 停顿 后 ， 那 些 使 用 NCSA | 
WWW 服务 器 的 用 户 开始 交换 他 们 用 于 该 服务 器 的 补丁 程序 , 他 们 也 很 快 认识 到 成 立 管理 | 
这 些 补丁 程序 的 论坛 是 必要 的 。 就 这 样 ,诞生 了 Apache Group， 后 来 该 团体 在 NCSA 的 基 | 
础 上 创建 了 Apache。 | 


3. MySQL 
MySQL 是 一 个 小 型 关系 型 数据 库 管理 系统 ， 开 发 者 为 瑞典 MySQL AB 公司 。 该 公司 | 


可 
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在 2008 年 1 月 16 日 被 Sun 公司 收 购 。 而 2009 年 , Sun 公司 又 被 Oracle 收购 .对 于 MySQL 
的 前 途 ， 没 有 人 持 乐 观 的 态度 。 目 前 MySQL 被 广泛 地 应 用 在 Intemet 上 的 中 小 型 网 站 中 。 
由 于 其 体积 小 、 速 度 快 、 总 体 拥有 成 本 低 ， 尤 其 是 开放 源码 这 一 特点 ， 许 多 中 小 型 网 站 为 
了 降低 网 站 总 体 拥有 成 本 而 选择 了 MySQL 作为 网 站 数据 库 。 

4. 运行 环境 的 搭建 


搭建 运行 环境 的 操作 步骤 如 下 : 
(1) 通过 互联 网 下 载 Apache、PHP、MYySQL 的 软件 安装 包 。 
(2) 双击 Apache_2.2.8-win32-x86-no_ssl.msi 文件 ， 弹 出 欢迎 界面 (这 里 以 2.2.8 版 本 


为 例 )。 单 击 Next 按钮 直至 进入 Server Infonmation 页 。 在 服务 器 信息 页 ， 用 户 需 要 根据 自身 情 
| 况 填 写 用 户 资料 。 然 后 单 击 Next 按钮 继续 选择 安装 类 型 和 路 径 。 继 续 单 击 Next 按钮 直至 安装 完 
| 成 。 完 成 安装 后 启动 Apache 即 可 完成 Apache 服务 器 的 配置 工作 。 


(3) 将 PHP 5.0 的 安装 文件 php-5.2.5-Win32.zip 解压 到 相应 目录 下 (这 里 以 5.2.5 版 


| 本 为 例 )。 在 php5.0 和 ext 文件 夹 下 找到 libmysql.dll、mbsthing.dll、mysql.dll 和 php5ts.dll 
文件 ， 并 复制 到 系统 盘 Windows\system32 目录 下 。 然 后 将 文件 php.ini-dist 复制 到 系统 盘 \ 
| Windows 目录 下 ， 并 重新 命名 为 php.ini。 找 到 “:extension=php_ mysqldl” 这 一 行 ， 将 前 
| 面 的 分 号 “;” 去 掉 。 这 样 ，PHP 就 可 以 支持 MySQL 数据 库 了 。 如 果 需 要 加 载 其 他 模块， 
| 方法 是 相同 的 。 保 存 后 ， 重 新 启动 Apache 服务 器 。 


(4) 双击 MySQL 安装 文件 mysql-essential-5.0.51-win32.msi， 进 入 欢迎 界面 (这 里 以 


| 5.0.51 版 本 为 例 )。 选 择 相关 配置 ， 单 击 Next 按钮 直至 MySQL 安装 结束 。 


(5) 配置 Apache 服务 器 和 PHP 5.0。 用 户 可 以 通过 修改 Apache 根 目录 下 conf 目录 


| 中 的 httpd conf 文件 ， 使 Apache 可 以 解析 PHP 文件 。 


| 说明: 


除了 手动 配置 运行 环境 外 ， 也 可 以 使 用 PHP 集成 环境 。 读 者 可 根据 自身 的 实际 情况 来 添 


加 一 些 集成 环境 的 介绍 。 其 中 集成 环境 的 介绍 将 在 第 8 章 中 给 出 详细 说 明 ， 这 里 不 再 殉 述 。 


7.7.3 ”相关 技术 


1. PHP 的 工作 原理 及 相关 技术 


PHP (HyperText Preprocessor) 是 一 种 多 平台 无 颖 运行 的 服务 器 端 嵌 入 式 脚本 语言 ， 
融合 了 C、Java 和 Perl 等 编程 语言 ， 由 于 它 是 一 种 免费 的 软件 ， 具 有 自由 软件 的 性 质 ， 版 
本 更 新 速度 快 、 移 植 速度 快 ， 并 具有 丰富 的 函数 库 功 能 ， 因 而 很 快 得 到 用 户 认 可 ， 特 别 是 
PHP 提供 加 密 函 数 库 ， 适 合 对 安全 性 要 求 较 高 的 电子 商务 网 站 ， 在 Apache 环境 下 构建 的 
PHP 网 站 已 经 成 为 当前 流行 的 Web 网 站 之 一 。 

PHP 能 够 作为 Apache Web 服务 器 的 模块 执行 ， 使 得 它 的 执行 效率 要 高 于 普通 的 CGI 
程序 ， 而 且 能 比 CGI 或 者 Perl 更 快速 地 执行 动态 网 页 。 
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使 用 者 如 果 创 建 了 一 个 PHP 应 用 程序 ， 实 际 上 相当 于 创建 了 一 个 PHP 脚本 文件 。 在 | 
服务 器 将 输出 信息 发 送 到 客户 端 之 前 , 网 络 服务 器 会 率先 将 文件 中 的 PHP 语言 进行 加 工 处 | 
理 。 如 果 服 务 器 不 支持 PHP， 通 常情 况 下， 网络 服务 器 会 直接 将 超 文本 文件 送 到 客户 的 浏 | 
览 器 上 以 表示 对 HTTP 的 要 求 作出 应 答 ; 如果 服 务 器 支持 PHP， 则 在 服务 器 响应 一 个 对 | 
PHP 文件 的 请 求 时 ， 进 行 下 列 处 理 ， 首先 在 一 个 PHP 文件 内 ， 标 准 的 HTML 编码 会 被 直 ;| 
接送 到 浏览 器 上 ， 而 内 嵌 PHP 程序 却 是 先 被 网 络 服 务 器 解释 执行 。 如 果 是 标准 输出 ,输出 | 
信息 也 将 作为 标准 的 HTML 而 被 送 至 浏览 | 

PHP 可 以 安装 在 UNIX/Linux 环境 下 ， 也 可 以 安装 在 Windows 环境 下 。 目 前 网 站 使 用 | 
最 多 的 、 最 理想 的 便 是 PHP+MySQL+Apache 基于 UNIX/Linux 下 的 服务 器 策略 。 | 


2，JavaScript 语言 


JavaScript 是 一 种 基于 对 象 和 事件 驱动 并 具有 相对 安全 性 的 客户 端 脚本 语言 。 同 时 也 | 
是 一 种 广泛 用 于 客户 端 Web 开发 的 脚本 语言 ， 常 用 来 给 HTML 网 页 添加 动态 功能 ， 如 响 | 
应 用 户 的 各 种 操作 。 它 最 初 由 NetScape 公司 的 Brendan Eich 设计 ， 是 一 种 动态 、 弱 类 型 、 | 
基于 原型 的 语言 内置 支持 类 。JavaScript 是 Sun 公司 的 注册 商标 。 Ecma 国际 以 JavaScript | 
为 基础 制定 了 ECMAScript 标准 。JavaScript 也 可 以 用 于 其 他 场合 ， 如 服务 器 端 编程 。 完 整 | 
的 JavaScript 实现 包含 3 个 部 分 : ECMAScript、 文 档 对 象 模 型 和 字 节 顺序 记号 。 | 

Netscape 公司 在 最 初 将 其 脚本 语言 命名 为 LiveScript， 后 来 Netscape 在 与 Sun 合作 之 | 
后 将 其 改名 为 JavaScript。JavaScript 最 初 是 受 Java 启发 而 开始 设计 的 ， 目 的 之 一 就 是 “看 | 
上 去 像 Java”， 因 此 语法 上 有 类 似 之 处 ， 一 些 名 称 和 命名 规范 也 借 自 Java。 但 JavaScript | 
的 主要 设计 原则 源 自 Self 和 Scheme。JavaScript 与 Java 名 称 上 的 近似 ， 是 当时 Netscape | 
公司 出 于 营销 考虑 与 Sun 公司 达成 协议 的 结果 。 为 了 取得 技术 优势 ， 微 软 推出 了 JScript | 
来 迎战 JavaScript 的 脚本 语言 。 为 了 互 用 性 ，Ecma 国际 (前 身 为 欧洲 计算 机 制造 商 协会 ) | 
创建 了 ECMA-262 标准 (ECMAScript)。 现 在 两 者 都 属于 ECMAScript 的 实现 。 尽 管 | 
JavaScript 是 作为 给 非 程序 人 员 的 脚本 语言 ， 而 不 是 作为 给 程序 人 员 的 编程 语言 来 推广 和 | 
宣传 ， 但 是 JavaScript 具有 非常 丰富 的 特性 。 | 

3，CSS 样式 表 | 

CSS (Cascading Style Sheet， 层 营 样 式 表 或 级 联 样式 表 ) 是 一 组 格式 设置 规则 ， 用 于 | 
控制 Web 页 面 的 外 观 。 通 过 使 用 CSS 样式 设置 页 面 的 格式 ， 可 将 页 面 的 内 容 与 表现 形式 | 
分 离 。 页 面 内 容 存放 在 HTML 文档 中 ， 而 用 于 定义 表现 形式 的 CSS 规则 则 存放 在 另 一 个 | 
文件 中 或 HTML 文档 的 某 一 部 分 , 通常 为 文件 头 部 分 。 将 内 容 与 表现 形式 分 离 , 不 仅 可 使 | 
维护 站 点 的 外 观 更 加 容易 , 而 且 还 可 以 使 HTML 文档 代码 更 加 简练 , 缩短 浏览 器 的 加 载 时 间 。 | 


7.7.4 ”B/S 结构 简介 


B/S (Browser/Server， 浏 览 器 /服务 器 结构 ) 是 Web 兴起 后 的 一 种 网 络 结构 模式 ，Web 
浏览 器 是 客户 端 最 主要 的 应 用 软件 。 这 种 模式 统一 了 客户 端 ， 将 系统 功能 实现 的 核心 部 分 | 
集中 到 服务 器 上 ， 简 化 了 系统 的 开发 、 维 护 和 使 用 。 客 户 机 上 只 要 安装 一 个 浏览 器 | 
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(Browser), 如 Netscape Navigator 或 Intemet Explorer, 服务 器 安装 Oracle、 Sybase、 Informix 
| 或 SQL Server 等 数据 库 。 浏 览 器 通过 Web Server 同 数据 库 进 行 数据 交互 。B/S 结构 如 
| 图 72 所 示 。 


ley lel 


客户 机 1 客户 机 2 客户 机 3 客户 机 机 


图 7.2 B/S 结构 图 
7.8 需求 分 析 


| 。。 随 着 计算 机 系统 功能 的 大 众 化 发 展 趋势 ， 为 充分 利用 计算 机 资源 ， 提 高 图 书馆 管理 工 
| 作 效率 ,减轻 图 书 管理 员 的 工作 负担 ， 实 现 管理 工作 的 信息 化 、 高 效 化 ， 做 好 图 书馆 管理 
| 系统 就 成 为 各 图 书馆 改善 工作 的 需求 。 

7.8.1 可 行 性 分 析 

| 1 系统 的 必要 性 

| 通过 计算 机 对 图 书 进行 管理 ， 不 仅 为 图 书馆 的 管理 注入 了 新 的 生机 ， 而 且 在 运营 过 程 
| 中 节省 了 大 量 的 人 力 、 物 力 、 财 力 和 时 间 ， 可 以 提高 图 书馆 的 管理 效率 ， 还 为 图 书馆 在 读 
者 群 中 树立 了 一 个 全 新 的 形象 ， 为 图 书馆 的 日 后 发 展商 定 了 一 个 良好 的 基础 。 随 着 计算 机 
| 技术 的 发 展 以 及 计算 机 在 各 企 事业 单位 中 应 用 的 普及 ， 计 算 机 强大 的 功能 已 为 人 们 深刻 认 
| 识 。 它 在 当今 高 速 发 展 的 信息 时 代 占 据 着 不 可 或 缺 的 地 位 , 作为 计算 机 应 用 软件 的 一 部 分 ， 
使 用 计算 机 对 图 书馆 进行 综合 管理 已 经 远 远 超过 手工 管理 的 效率 。 因 此 ， 开 发 这 样 一 个 管 
| 理 系统 是 很 有 必要 的 。 

| 2， 系统 的 可 行 性 


| 动态 网 络 技术 的 主流 可 以 分 为 PHP 技术 、JSP 技术 和 .NET 技术 。 这 3 种 Web 开发 语 
| 言 都 可 以 完美 地 实现 图 书馆 管理 系统 的 软件 编制 ， 而 目前 存在 的 各 种 网 络 终端 服务 器 也 具 


了 。314 。 
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备 运行 该 系统 的 条 件 。 本 系统 采用 了 开源 性 较 好 且 易 于 开发 和 维护 的 PHP 语言 , 利用 当前 
网 站 流行 的 构架 方式 (ApacherMySQL+PHP)， 并 应 用 Windows 作为 搭载 平台 建立 整个 系 | 
统 的 Web 服务 器 。 由 于 Apache、MySQL 与 PHP 具有 较 好 的 兼容 性 ， 并 且 都 同属 于 开放 | 
源 软件 (FLOSS)， 因 此 ， 在 低 投 入 甚至 零 投 入 的 前 提 下 也 可 以 很 好 地 建立 起 一 个 稳定 、 
安全 、 免 费 的 网 络 管理 系统 。 


7.8.2 系统 需求 


根据 图 书馆 管理 系统 的 特点 ， 可 以 将 其 分 为 系统 设置、 读者 管理 、 图 书 档案 管理 、 图 | 
书 借 还 和 系统 查询 5 个 部 分 ， 其 中 各 部 分 及 其 包括 的 具体 功能 模块 如 图 7.3 所 示 。 


图 书馆 管理 系统 


亚 末 醋 击 轿 


则 二 外 隧 咯 
于 叫 耻 料 幅 茜 
瑚 叫 料 歼 帐 琳 
大 革 料 详 击 轿 
客 轩 否 棵 击 图 
柄 嵩 葡 灿 本 本 


图 7.3 图 书馆 管理 系统 功能 结构 图 


7.8.3 功能 需求 


通过 对 一 些 大 型 图 书馆 的 实际 考察 、 分 析 , 并 结合 图 书馆 的 要 求 以 及 实际 的 市 场 调查 ，| 
要 求 本 系统 具有 以 下 功能 | 
网 站 设计 页 面 要 求 美观 大 方 、 个 性 化 ， 功 能 全 面 ， 操 作 简单 

要 求实 现 基础 信息 的 管理 平台 。 

要 求 对 所 有 读者 进行 管理 。 

要 求实 现 图 书 借阅 排行 ， 了 解 当前 的 畅销 书 。 

商品 分 类 详尽 ， 可 按 不 同类 别 查 看 图 书信 息 。 

图 书 借阅 检索 功能 ， 保 证 数据 查询 的 灵活 性 。 

实现 图 书 借阅 、 图 书 续 借 、 图 书 归还 功能 。 | 
实现 综合 条 件 查询 ， 如 按 用 户 指定 条 件 查询 、 按 日 期 时 间 段 查询 、 按 综合 条 件 查 | 
询 等 。 | 
要 求 图 书 借阅 、 续 借 、 归 还 时 记 下 每 一 笔记 录 的 操作 员 。 

实现 对 图 书 借阅 、 续 借 和 归还 过 程 的 全 程 数 据 信息 跟踪 。 


加 加 罗网 同 网 罗网 


风 加 


.315 ， L_ 


人 Eap 项 目 业 全 分 析 


避 


回 ”提供 借阅 到 期 提醒 功能 ， 使 管理 者 可 以 及 时 了 解 到 已 经 到 达 归 还 日 期 的 图 书 借阅 


信息 。 
。 。 包 ”提供 灵活 、 方 便 的 权限 设置 功能 ， 使 整个 系统 的 管理 分 工 明确 。 
国内 | 。 回 具有 易 维护 性 和 易 操作 性 。 


7.8.4 性 能 要 求 
| 根据 前 面 所 作 的 需求 分 析 及 功能 的 需求 可 以 得 出 ， 图 书馆 管理 系统 实施 后 ， 应 达到 以 
| 下 系统 性 能 标准 ; 
| 网 站 整体 结构 和 操作 流程 合理 顺畅 ， 实 现 人 性 化 设计 。 
规范 、 完 善 的 基础 信息 设置 。 
对 操作 员 设 置 不 同 的 操作 权限 ， 为 管理 员 提 供 修改 权限 功能 。 
对 所 有 读者 进行 集中 管理 。 
对 图 书信 息 进行 集中 管理 。 
实现 图 书 借阅 排行 ， 以 便 了 解 当前 的 畅销 书 。 
提供 快速 的 图 书信 息 、 图 书 借阅 检索 功能 。 
实现 图 书 借阅 、 图 书 续 借 、 图 书 归 还 功能 。 
实现 综合 条 件 查询 ， 如 按 用 户 指定 条 件 查询 、 按 日 期 时 间 段 查询 、 按 综合 条 件 查 
询 等 。 
实现 图 书 借阅 、 续 借 、 归 还 时 记 下 每 一 笔记 录 的 操作 员 。 
支持 图 书 到 期 提醒 功能 。 
为 操作 员 提供 密码 修改 功能 。 
系统 运行 稳定 、 安 全 可 靠 。 


7.9 系统 数据 库 设计 


加 网 同 同 网 罗网 网 网 


网罗 罗网 


| 由 于 本 系统 是 为 中 小 型 图 书馆 开发 的 程序 ， 需 要 充分 考虑 成 本 问题 及 使 用 需求 (如 跨 

| 平台 ) 等 问题 ， 而 MySQL 是 世界 上 最 为 流行 的 开放 源码 的 数据 库 ， 是 完全 网 络 化 的 跨 平 

| 台 的 关系 型 数据 库 系统 ， 这 正好 满足 了 中 小 型 企业 的 需求 ， 所 以 本 系统 采用 MySQL 数据 库 。 
在 设计 图 书馆 管理 系统 之 前 ， 有 必要 说 明 数据 库 的 基本 概念 和 本 设计 所 应 用 的 数据 表 。 


7.9.1 数据 库 概述 


| 计算 机 信息 系统 以 数据 库 为 核心 ， 在 数据 库 管理 系统 的 支持 下 ， 进 行 信息 的 收集 、 整 

| 理 、 存 储 、 检 索 、 更 新 、 加 工 、 统 计 和 传播 等 操作 。 

| 对 于 数据 库 应 用 开发 人 员 来 说 ， 为 使 现实 世界 的 信息 流 计算 机 化 ， 并 对 计算 机 化 的 信 

| 息 进行 各 种 操作 ， 就 是 如 何 利用 数据 库 管理 系统 、 系 统 软 件 和 相关 硬件 系统 ， 将 用 户 的 要 

| 求 转化 成 有 效 的 数据 结构 ， 并 使 数据 库 结构 易于 实现 用 户 新 的 要 求 的 过 程 。 

| “确切 地 说 ， 数 据 库 设计 是 指 对 于 一 个 给 定 的 应 用 环境 ， 提 供 一 个 确定 最 优 数据 模型 与 
| “316 。 
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处 理 模式 的 逻辑 设计 ， 以 及 一 个 确定 数据 库存 储 结 构 与 存 取 方 法 的 物理 设计 ， 建 立 起 既 能 | 
反映 现实 世界 信息 和 信息 联系 ， 满 足 用 户 数据 要 求 和 加 工 要 求 ， 又 能 被 某 个 数据 库 管理 系 | 
统 所 接受 ， 同 时 能 实现 系统 目标 ， 并 有 效 存 取 数据 的 数据 库 。 | 

所 谓 数据 库 是 指 以 一 定 的 组 织 方式 存储 在 一 起 的 、 能 为 多 个 用 户 所 共享 的 、 与 应 用 程序 | 天 六 
彼此 独立 的 相关 联 的 数据 集合 。 而 数据 库 系统 是 指 实现 有 组 织 的 动态 的 存储 大 量 关联 数据 ， 本 
支持 多 用 户 访问 的 计算 机 软 硬 件 资源 与 数据 库 管 理 员 组 成 的 系统 。 个 人 系统 是 按 用 户 的 需求 | Note 
进行 数据 库 定义 、 存 取 、 运 行 、 建 立 和 维护 功能 的 ， 系 统 的 数据 库 定义 模型 如 图 7.4 所 示 。 


各 种 〈 源 ) 


(目标 ) 
模式 各 种 (目标 


模式 


图 74 数据 库 定义 模型 图 

7.9.2 系统 实体 E-R 图 | 
根据 实际 调查 及 对 系统 所 作 的 需求 分 析 、 系 统 设计 ， 规 划 出 本 系统 中 使 用 的 数据 库 实体 | 

分 别 为 图 书 档案 实体 、 读 者 档案 实体 、 借 阅 档案 实体 、 归 还 档案 实体 和 管理 员 实体 。 下 面 将 | 

介绍 几 个 关键 实体 的 ER 图 。 | 
1， 图 书 档案 实体 


图 书 档案 实体 包括 编号 、 条 形 码 、 书 名 、 类 型 、 作 者 、 译 者 、 出 版 社 、 价 格 、 页 码 、 
书架 、 输 入 时 间 和 操作 员 等 属性 。 图 书 档案 实体 的 E-R 图 如 图 7.5 所 示 。 


图 7.5 图 书 档案 实体 E-R 图 


2. 读者 档案 实体 


读者 档案 实体 包括 编号 、 姓名、 性 别 、 条 形 色 、 职 业 、 出 生日 期 、 有 效 证 件 、 证 件 号 到 、 电 | 
话 、 电 子 邮 件 、 登 记 日 期 、 操 作 员 、 类 型 和 备注 等 属性 。 读 者 档案 实体 的 ER 图 如 图 7.6 所 示 。 | 


er L_ 


(Eap 项 目 业 全 分 析 


区 


图 7.6 读者 档案 实体 E-R 图 


3， 借 阅 档案 实体 
| 借阅 档案 实体 包括 编号 、 读 者 编号 、 图 书 编号 、 借 书 时 间 、 应 还 时 间 、 操 作 员 和 是 否 
| 归还 等 属性 。 借 阅 档案 实体 的 ER 图 如 图 7.7 所 示 。 


图 7.7 借阅 档案 实体 E-R 图 


| 4 归还 档案 实体 


| “归还 档案 实体 包括 编号 、 读 者 编号 、 图 书 编号 、 归 还 时 间 和 操作 员 等 属性 。 归 还 档案 
| 实体 的 E-R 图 如 图 7.8 所 示 。 


归还 时 间 


图 7.8 ”归还 档案 实体 ER 图 


J “318.s 


7.9.3 系统 数据 表 设 计 


结合 实际 情况 及 对 用 户 需 求 的 分 析 , 图 书馆 管理 系统 db_library 数据 库 主 要 包含 10 个 
数据 表 ， 如 表 7.1 所 示 。 | 
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表 7.1 图 书馆 管理 系统 数据 表 


表 名 说 了 明 
tb_bookcase 图 书 书架 信息 表 
tb_bookinfo 图 书信 息 表 
tb borrow 图 书 借阅 信息 表 
tb libra 
也 _manager 
tb_parameter 参数 设置 信息 表 
tb_publishing 出 版 社 信息 表 
tb_purview 权限 信息 表 
tb reader 读者 信息 表 
tb readertype 读者 类 型 信息 表 


主要 数据 表 的 设计 结构 如 表 7.2 一 表 7.4 所 示 。 
1. tb_bookinfo (图 书信 息 表 ) 
图 书信 息 表 主 要 用 于 存储 图 书 的 基础 信息 。 该 数据 表 的 结构 如 表 7.2 所 示 。 


表 7.2 图 书信 息 表 结构 


字段 名 | 数据 类 型 说 明 
barcode Varchar(30 | | 图 书 条 形 码 
bookname varchar(70 | | 图 书 名 称 

ypeid Int(10; | 图 书 类 型 
author varchar(30 | | 图 书 作者 
translator varchar(30) 图 书 译 者 
ISBN varchar(20) 图 书 ISBN 
price float(8, 2) 图 书 定价 
page int(10) 图 书页 码 
bookcase int(10) 图 书 书架 
storage int(10， 图 书库 存 
inTime date | | 入 库 时 间 
operator Varchar(30) 操作 员 
del tinyint() 是 否 删除 
jd int(11) auto increment 自动 编号 ID 


2. tb borrow (图 书 借 阅 信 息 表 ) 
图 书 借阅 信息 表 主 要 用 于 存储 图 书 的 借阅 信息 。 该 数据 表 的 结构 如 表 7.3 所 示 。 


“319. 


人 Bo 项 目 业 例 分 析 


已 
表 7.3 图 书 借阅 信息 表 

字 段 名 数据 类 型 额 ” 外 说 明 
id int(10) auto_increment 自动 编号 ID 
readerid int(10 读者 ID 编号 
borrowTime date 图 书 借阅 时 间 
vkiine | i | | 图 书 归还 时 间 
operator varchar(30) 操作 员 
ifback tinyint(1) 是 否 归还 


3. tb reader (读者 信息 表 ) 


读者 信息 表 主 要 用 于 存储 读者 的 基础 信息 。 该 数据 表 的 结构 如 表 7.4 所 示 。 


表 7.4 读者 信息 表 


字 段 名 数据 类 型 额 外 说 了 明 
id int(10) 自动 编号 ID 
name varchar(20) | | 读者 姓名 
sex varchar(4) | | 性 别 
barcode varchar(30 | | 读者 条 形 码 
Vocation varchar(50) | | 读者 职业 
birthdis date | | 出 生日 其 
papeType varchar(10, | | 读者 证 件 
papeNO varchar(20) | | 证 件 号 人 码 
tel Varchar(20 | | 读者 电话 
email varchar(100. | | E-mail 地 址 
createDate date | | 办 卡 时 间 
operator Varchar(30 | | 操作 员 
remark mediumtext 一 一 一 一 一 备注 

ypeid int(11) 读者 类 型 


7.10.1 系统 实现 关系 图 


图 书馆 管理 系统 的 流程 如 图 7.9 所 示 。 


7.10 系统 


“320 。 


设计 
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y y 
图 书 借 阅 | | 图 书 续 借 | 图 书 归还 


管理 图 书 档案 信息 |- | 图 书 档案 


管理 读者 档案 信息 


完成 图 书 借阅 


获取 读者 信息 


IE 


图 7.9 图 书馆 管理 系统 流程 图 

7.10.2 ”系统 功能 模块 设计 

1. 系统 的 功能 模块 
经 实际 考察 、 分 析 ， 基 于 图 书馆 发 展 需求 ， 现 将 图 书馆 管理 系统 按照 功能 划分 为 管 
、 图 书 档案 管理 和 图 书 借 还 等 功能 模块 。 其 中 ， 管 理 员 模块 主要 用 于 实现 管理 员 登 录 、 | 
管理 员 添 加 、 设置 管理 员 、 删 除 管理 员 等 过 程 ; 图 书 档案 管理 模块 主要 实现 图 书信 息 添加 、， 
图 书信 息 修改 、 删 除 图 书信 息 等 过 程 ， 图 书 借 还 模块 主要 用 于 实现 图 书 的 借阅 、 续 借 、 归 | 
还 和 借阅 查询 等 功能 。 | 

2， 系 统 功能 模块 特点 | 

整个 图 书馆 管理 系统 不 但 可 以 按照 整体 需求 实现 各 种 功能 ， 同 时 也 可 以 帮助 图 书馆 管 | 
理 人 员 安全 、 稳 定 、 高 效 地 实现 管理 体制 。 其 中 管理 员 模块 采用 权限 判断 机 制 来 实现 登录 | 
过 程 ， 图 书 档案 管理 模块 具有 快速 查询 ， 易 于 维护 、 管 理 ， 方 便 查 看 等 功能 特点 ;图书 借 | 
还 模块 可 以 更 改 用 户 的 图 书 借阅 状态 ， 以 此 来 实现 图 书 借阅 系统 的 完整 性 。 | 
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7.11 系统 功能 实现 


7.11.1 管理 员 模 块 设计 


管理 员 模块 主要 包括 管理 员 登录 、 查 看 管理 员 列表 、 添 加 管理 员 信息 、 管 理 员 权限 设 | 
Se 2 Le 
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”和 置 、 删 除 管理 员 和 更 改口 令 6 个 功能 。 


EN 
臣 
岂 
着 


会 内 系统 登录 是 进入 图 书馆 管理 系统 的 入 口 ， 主 要 用 于 验证 管理 员 的 身份 。 运 行 本 系统 ， 

人 一】 首先 进入 的 是 系统 登录 页 面 ， 在 该 页 面 中 ， 系 统管 理 员 可 以 通过 输入 正确 的 管理 员 名称 和 

密码 登录 到 系统 首页 ， 当 用 户 没有 输入 管理 员 名 称 或 密码 时 ， 系 统 会 通过 JavaScript 进行 
| 判断 ， 并 给 予 信息 提示 。 系 统 登 录 页 面 的 运行 结果 如 图 7.10 所 示 。 


(TT 


ATN: (S99 
DG” 琶 | 彻 


| 图 7.10 系统 登录 页 面 的 运行 结果 
| 系统 登录 页 面 主 要 用 于 收集 管理 员 的 输入 信息 及 通过 自 定义 的 JavaScript 函数 验证 输 
入 信息 是 否 为 空 。 该 页 面 中 所 涉及 的 表单 元 素 如 表 7.5 所 示 。 

表 7.5 系统 登录 页 面 所 涉及 的 表单 元 素 


a 和 
[eu la | 
| password js | 
| smit | valwes"the" onclicke"remum check(fonml)" | 
| rset |vwueER" | 
[mm | 


Value=" 关 闭 " onClick="window.closeO:" 


2. 查看 管理 员 列 表 


| 管理 员 登 录 后 ， 单 击 “ 系 统 设置 ” /“ 管 理 员 设置 ” 超 链接 ， 可 进入 查看 管理 员 列 表 页 面 。 
| 在 该 页 面 中 ， 将 以 表格 的 形式 显示 全 部 管理 员 及 其 权限 信息 ， 并 提供 添加 管理 员 信息 、 删 除 
| 管理 员 信息 和 设 害 管 理 员 权限 的 超 链接 。 查 看 和 管理 员 列 表 页 面 的 运行 结 寺 果 如 图 7.11 所 示 。 


和 和 By a 
所 所 ms WN 

日 rm Ras WW 

F rm eas Ms 


| 图 7.11 查看 管理 员 列表 页 面 的 运行 结果 
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3. 添加 及 删除 管理 员 
管理 员 登 录 后 ， 单 击 “ 系 统 设置 ”/“ 管 理 员 设置 ” 超 链接 ， 可 进入 可 看 管理 员 列 表 页 
面 ， 在 该 页 面 中 单 击 “ 添 加 管理 员 信息 ” 超 链接 ， 可 打开 添加 管理 员 信息 页 面 。 添 加 管理 | 
员 信息 页 面 的 运行 结果 如 图 7.12 所 示 。 | 


当 http-//127.0.0.1 -添加 各 理 达 信 种 革 ]eEE3 


: ”图书 要 好 者 ] ! 


图 7.12 添加 管理 员 信 息 页 面 的 运行 结果 | 

在 查看 管理 员 列 表 页 面 ， 单 击 指定 管理 员 信息 后 面 的 “删除 ” 超 链 接 ， 可 将 该 管理 员 

及 其 权限 信息 删除 。 | 
4. 设置 管理 员 权 限 


在 查看 管理 员 列 表 页 面 单 击 指定 管理 员 后 面 的 “权限 设置 ” 超 链接 ， 可 进入 权限 设 | 
置 页 面 ， 设 置 该 管理 员 的 操作 权限 。 权 限 设置 页 面 的 运行 结果 如 图 7.13 所 示 。 


ETIZ /127.0.0./mr/schoolboo ae 汪 S| xl| 


管理 员 名 称 : 国 达 好 痢 
厂 系统 设置 “三 读者 管理 


拥有 的 权限 : 区 图 书 管理 。 图 书 借 还 
克 系统 查询 


[本 并 


图 7.13 权限 设置 页 面 的 运行 结果 
权限 设置 页 面 中 所 涉及 的 表单 元 素 如 表 7.6 所 示 。 

表 7.6， 权 限 设置 页 面 所 涉及 的 表单 元 素 | 
名 称 | 元 素 类 型 重要 属性 含 义 | 


forml form method="post" action="manager_modifyok.php" 表单 | 
id hidden value="<2php echo Sinfo[id]:?>" 管理 员 编号 | 
Dame text value="<?php echo $info[name]:?>" 管理 员 名 称 | 
sysset checkbox <?php if($info[sysset]=—=1){ echo("checked"):}?> 系统 设置 | 
readerset checkbox <?php if($info[readerset]——1){ echo("checked"):}?> 读者 管理 | 
bookset checkbox <?php if($info[bookset]==1){echo("checked"):}?> 图 书 管理 | 
borrowback checkbox <?php if($info[borrowback]==1){echo("checked"):Y}?> | 图 书 借 还 | 
Sysquel checkbox <?php if($info[sysquery]—1){echo("checked"):}?> 系统 查询 | 
submit submit class="btn grey" “保存 ”按钮 | 
Submit2 button value=" 关 闭 " onClick="window.closeO:" “关闭 ”按钮 | 
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7.11.2 图 书 档案 管理 模块 设计 

| 。。 图书 档案 管理 模块 主要 包括 查看 图 书信 息 列表 、 添 加 图 书信 息 、 修 改 图 书信 息 、 删 除 
| 图 书信 息 和 查看 图 书 详细 信息 5 个 功能 。 

| 1 查看 图 书信 息 列表 


管理 员 登 录 后 ， 单 击 “ 图 书 档案 管理 ” 超 链 接 ， 可 进入 查看 图 书信 息 列表 页 面 ， 在 该 
页 面 中 将 显示 全 部 图 书信 息 列表 ， 同 时 提供 添加 、 删 除 和 修改 图 书信 息 的 超 链 接 。 查 看 图 
书信 息 列表 页 面 的 运行 结果 如 图 7.14 所 示 。 


图 7.14 查看 图 书信 息 列表 的 运行 结果 


另外 ， 图 书馆 管理 员 可 以 通过 单 击 “ 删 除 ” 列 下 的 “删除 ” 超 链接 来 实现 指定 图 书 的 
删除 。 


| 2， 派 加 图 书信 息 
在 查看 图 书信 息 列表 页 面 中 单 击 “ 添 加 图 书信 息 ” 超 链接 , 可 进入 添加 图 书信 息 页 面 。 
深 加 图 蔬 信息 页 面 的 运行 结果 如 图 715 所 示 。 


图 7.15 添加 图 书信 息 页 面 的 运行 结果 


| 添加 图 书信 息 页 面 主要 用 于 收集 输入 的 图 书信 息 以 及 通过 自 定义 的 JavaScript 函数 验 
| 证 输入 信息 是 否 合法 。 该 页 面 所 涉及 的 重要 表单 元 素 如 表 7.7 所 示 。 
二 . 324 . 


名 称 


第 7 章 图 书馆 管理 系统 (PHP+MYSQL 5.0 实现 ) 


表 7.7 添加 图 书信 息 页 面 所 涉及 的 重要 表单 元 素 


元 素 类 型 


重要 属性 


forml 


form 


method="post" action="book_ok.php" 


typeld 


isbn 


bookcaseid 


operator 
Submit 
Submit2 


3， 修改 图 


在 查看 图 书 列表 页 pier nin ei de “修改 ” 超 链 接 ， 可 进入 修改 图 


书信 息 页 面 。 修 


select 


select 


select 


hidden 
submit 
button 


书信 息 


<2php include("Conn/conn.php"); 

$sql=mysql_query("select * from tb_booktype"); 

$info=mysql fetch array($sq]l); 

do{ 

?> 

<option value="<?php echo $info[id];?>"> 

<2php echo S$info[typename]; ?></option> 
ql_fetch_array($sqD)):?> 


Zphp 

$sql2=mysql query("select * from tb_publishing"); 
S$info2=mysql_fetch_array($sql2); 
dof 


?> 
<option value="<?php echo $info2[ISBN];?>"> 
<?php echo $info2[pubname]:;?></option> 

ql_fetch array($sql2)):?> 


$sql3—mysql_query("select * from tb_bookcase"); 
S$info3=mysql_fetch_array($sql3); 

dof 

?> 

<option value="<?php echo $info3[id];?>"> 

<?php echo $info3[name];?></option> 

<?php }while($info3=mysql_fetch_array($sql3)):2> 


value="<?php echo $info3[name]:?>" 
onClick="return check(form1)" 


onClick="history.backO:" 


获 改 图 书信 息 页 面 的 运行 结果 如 图 7.16 所 示 。 


ES EJ 


图 7.16 修改 图 书信 息 页 面 的 运行 结果 
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图 书 类 型 


出 版 社 


书架 名 称 


操作 员 
“保存 ”按钮 
“返回 ”按钮 


Ey 


人 Ptp 项 目 灶 人 讽 委 析 


| 7.11.3 图 书 借 还 模块 设计 


| 图 书 借 还 模块 主要 包括 图 书 借阅 、 图 书 续 借 、 图 书 归还 、 图 书 档案 查询 、 图 书 借阅 查 
会 内 | 询 和 借阅 到 期 提醒 6 个 功能 。 在 图 书 借阅 模块 中 的 用 户 只 有 操作 员 一 种 身份 ， 通 过 该 身份 
和 NA | 可 以 进行 图 书 借 还 等 相关 操作 。 图 书 借 还 模块 的 用 例 图 如 图 7.17 所 示 。 


WE 
| 图 书 档案 查询 图 书 借阅 


(Eeema) Ceemm)- 
借阅 到 则 提要 这 


图 7.17 图 书 借 还 模块 的 用 例 图 


Case ) 


1.， 图 书 借阅 
| 管理 员 登 录 后 ， 单 击 “ 图 书 借 还 ”/“ 图 书 借阅 ” 超 链 接 ， 可 进入 图 书 借阅 页 面 ， 在 该 
| 页面 中 的 “读者 条 形 码 ”文本 框 中 输入 读者 的 条 形 码 ( 如 1234561789) 后 ， 单 击 “确定 ” 
| 按钮， 系统 会 自动 检索 出 该 读者 的 基本 信息 和 未 归还 的 借阅 图 书信 息 。 如 果 检 索 到 对 应 的 
| 读者 信息 ， 则 将 其 显 EE 示 在 页 面 中 ， 此 时 输入 图 书 的 条 形 码 或 图 书 名 称 后 ， 单 击 “ 确 定 ” 按 
| 钮 ， 可 借阅 指定 的 图 书 。 图 书 借阅 页 面 的 运行 结果 如 图 7.18 所 示 。 


人 民 于 电 出 新 半 
人 民 取 电 出 站 


图 7.18 图 书 借阅 页 面 的 运行 结果 


| 说 明 : 
| 当 读者 借阅 图 书 完毕 后 ,操作 员 单 击 “ 完 成 借阅 ”按钮 ， 即 可 重新 载 入 图 书 借阅 页 面 ， 
| 当前 页 处 于 空 信息 状态 ， 从 而 方便 操作 员 进 行 下 一 个 读者 借阅 图 书 操作 。 


| 图 书 借阅 页 面 总 体 上 可 以 分 为 两 部 分 : 一 部 分 用 于 查询 并 显示 读者 信息 ; 另 一 部 分 用 
| 于 显示 和 添加 读者 的 借阅 信息 ,图书 借阅 页 面 在 Dreamweaver 中 的 设计 效果 如 图 7.19 所 示 。 
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图 7.19 图 书 借阅 页 面 的 设计 效果 


在 进行 图 书 借阅 时 ， 系 统 要 求 每 个 读者 只 能 同时 借阅 一 定数 量 的 图 书 ， 并 且 该 数量 由 | 
读者 类 型 表 tb readerType 中 的 可 借 数量 number 决定 ,所 以 在 此 编写 了 自 定义 的 checkbookO | 
函数 ， 用 于 判断 当前 选择 的 读者 是 否 还 可 以 借阅 新 的 图 书 ， 同 时 该 函数 还 具有 判断 输入 读 | 
者 条 形 码 或 图 书 名 称 文本 框 是 否 为 空 的 功能 。 

2. 图 书 续 借 

管理 员 登 录 后 ， 单 击 “ 图 书 借 还 ”/“ 图 书 续 借 ” 超 链 接 ， 可 进入 图 书 续 借 页 面 。 在 该 
页 面 中 的 “读者 条 形 码 ”文本 框 中 输入 读者 的 条 形 码 (如 1234561789) 后 ， 单 击 “ 确 定 ” 
按钮 ， 系 统 会 自动 检索 出 该 读者 的 基本 信息 和 未 归还 的 借阅 图 书信 息 。 如 果 检 索 到 对 应 的 
读者 信息 ， 则 将 其 显示 在 页 面 中 ， 此 时 单 击 “ 续 借 ” 超 链接 ， 即 可 续 借 指 定 图 书 〈 即 将 该 
图 书 的 归还 时 间 加 上 该 书 的 可 借 天 数 30 天 计算 得 出 应 还 时 间 )。 图 书 续 借 页 面 的 运行 结果 | 
如 图 7.20 所 示 。 


当前 位 时; 图 入 下 》 了 攻 和 人 


MEE | 
| 

二 者 天 证 如 ”和 名: 隔 丽 任 虽 : 区 | 
读者 条 到: He : EE ia: Eom | | 
[Ea 天 让 | 。。 流 3s: RS 再 ]。 a: 王 ]m | 
| 

办 [7 ED 砚 殉 失 GD) _ 尖 二 ! 

Tm 二 由 双关 大和 zoUi-05-08 。 playrg 。。 人 和 中 出 版 村 。 PTA 和 mm Eo | 
?0 区 所 下 系 红 开 示人 竹 用 291-05-t2 。 Pi-05-I2 人 Rei 由 所 二 hr 5 人 本 | 


图 7.20 图 书 续 借 页 面 的 运行 结果 


说 明 : | 
当 读 者 续 借 完 图 书后 ， 操 作 员 单 击 “ 完 成 续 借 ”按钮 ， 即 可 重新 载 入 “图 书 续 借 ” 页 | 
面 ， 当 前 页 处 于 空 信息 状 态 ， 从 而 方便 操作 员 进行 下 一 个 读者 续 借 图 书 操作 。 | 


图 书 续 借 页 面 的 设计 方法 同 图 书 借阅 页 面 类 似 ， 所 不 同 的 是 ， 在 图 书 续 借 页 面 中 没有 


添加 借阅 图 书 的 功能 ， 而 是 添加 了 “ 续 借 ” 超 链接 。 图 书 续 借 页 面 在 Dreamweaver 中 的 设 | 
计 效 果 如 图 7.21 所 示 。 | 
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图 7.21 图 书 续 借 页 面 的 设计 效果 
3， 图 书 归还 


管理 员 登 录 后 ， 单 击 “ 图 书 借 还 ”/“ 图 书 归 还 ” 超 链 接 ， 可 进入 图 书 归 还 页 面 。 在 该 
页 面 中 的 “读者 条 形 码 ” 文 本 框 中 输入 读者 的 条 形 码 〈 如 1234561789) 后 ， 单 击 “ 确 定 ” 


| 按钮 ， 系 统 会 自动 检索 出 该 读者 的 基本 信息 和 未 归还 的 借阅 图 书信 息 。 如 果 检索 到 对 应 的 
| 读者 信息 ， 则 将 其 输出 到 浏览 器 ， 此 时 单 击 “ 归 还 ” 超 链接 ， 即 可 将 指定 图 书 归 还 。 图 书 


| 归还 页 面 的 运行 结果 如 图 7.22 所 示 。 


图 Wi 坟 浆 ta i 出 白 社 + 全 从 GY 。。_ 完 所 不 
D0 下 学 委 大全 9-0e- 乓 2041-05-06 人员 半 昌 MK 福 DID 下 基 加 四 4 
0 外 肛 备 东 饥 开 发 全 玫 出 。 2043-02-06 。 3011-05-06。。 人员 部 昌 d 屋 入。 了 0D 书 兹 0 WE 


图 722 ”图书 归还 页 面 的 运行 结果 
7.12 结 论 


本 设计 以 PHP 为 开发 基础 ， 结 合 CSS、JavaScript 等 主流 技术 实现 图 书馆 管理 系统 。 
着 重 对 图 书馆 管理 体制 的 研究 , 本 设计 围绕 主流 Web 开发 应 用 技术 , 结合 动态 网 站 开发 特 
点 及 需求 ， 根 据 系统 运行 环境 、 设 计 系统 软件 对 图 书馆 管理 系统 的 研究 进行 讲解 。 本 次 设 
计 中 的 数据 库 采用 MySQL， 选 用 该 数据 库 既 可 以 提高 系统 的 安全 性 与 稳定 性 ， 同 时 也 极 
大 地 降低 了 开发 成 本 。 另 外 ， 程 序 的 运行 采用 AppServ 集成 环境 ， 也 保证 了 软件 之 间 的 协 
同 作用 。 利 用 PHP 开源 性 与 易 开发 性 等 特点 开发 程序 , 给 整个 过 程 带 来 了 很 大 方便 , 但 本 
系统 只 能 满足 绝 大 多 数 功能 需求 ， 对 于 各 个 图 书馆 的 实际 情况 ， 仍 需要 根据 个 体 因素 进 一 
步 对 程序 进行 调整 。 该 图 书馆 管理 系统 仍 有 待 于 完善 。 
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本 论文 是 在 XX 老师 的 悉心 指导 下 完成 的 。 在 选 题 、 设 计 及 撰写 论文 过 程 中 ，XX 老 | 
师 均 给 予 了 我 莫大 的 指导 和 帮助 ， 他 的 适时 鞭策 、 及 时 纠正 和 鼓励 使 我 慢 慢 走出 了 程序 设 | 
计 的 困顿 ， 积 累 了 很 多 经 验 ， 并 完成 了 预期 的 任务 。 在 此 ， 特 向 XX 老师 表示 我 衷心 的 感 | 
激 和 深切 的 谢意 。 | 

在 此 期 间 ， 我 还 得 到 了 很 多 同学 的 帮助 ， 在 此 一 并 向 他 们 表示 感谢 。 

感谢 XX 师范 大 学 对 我 四 年 来 的 培养 ， 感 谢 所 有 关心 和 帮助 我 的 老师 和 同学 们 ! 


7.15 附 录 


附录 主要 包括 与 设计 论文 ) 有 关 的 图 表 、 程 序 、 运 行 结 果 ， 以 及 主要 设备 、 仪 器 仪 
表 的 性 能 指标 和 测试 精度 等 内 容 。 | 


7.15.1 ”附录 人 A 主 程序 (Index.php 代码 ) 


01 <?php 

02 include ("check login.php'); 
03 include("conn/conn.php"); 
04 Ye 


2329s Se 


项 目 案 例 分 析 


<html> 

<meta http-equiv="Content-Type" content="text/html:; charset=gb2312"> 

<head> 

<title> 学 校 图 书馆 管理 系统 </title> 

<link href="CSS/style.css" rel="stylesheet"> 

</head> 

11 <table width="776" border="0" align="center" cellpadding="0" cellspacing="0" class= 
| "tableBorder"> 


12 <tr> 

13 <td> 

14 <?phpinclude("navigation.php"); ?> 
15 </td> 

16 </tr> 


LE/ <td bgcolor="#FFFFFF"> 

18 <table width="100%" border="0" cellspacing="0" cellpadding="0"> 

19 <tr> 

20 <td valign="top" bgcolor="#FFFFFF"> 

21 <table align="center" cellpadding="0" cellspacineg="0" bgcolor="#FFFFFF" class= 
"tableBorder gray"> 


<tr> 

23 <td align="center" valign= "top" style="padding:Spx:"> 

24 <table width="738" border="0" cellpadding="0" cellspacing= "0"> 

25 <tr> 

26 <td height="148" valign="top"><table width="738" border="0" cellspacing= 
"0" cellpadding="0"> 

27 <tr> 

28 <td width="753" height="44" background= "Images/main booksort. 
gif'>&nbsp;</td> 

29 </tr> 

30 <tr> 

31 <td height="72" valign="top" background= "Images/main booksor t_1. 


了 2 <table cellspacing="0" bordercolor="#FFFFFF" bordercolordark="#D2E3E6" bordercolorlight 


33 <tr align="center"> 

34 <td width="4%" height="25"> 排 名 </td> 

35 <td width="10%"> 图 书 条 形 码 </td> 

36 <td width="22%"> 图 书 名 称 </td> 

37 <td width="11%'> 图 书 类 型 </td> 

38 <td width="9%"> 书 架 </td> 

39 <td width="13%"> 出 版 社 </td> 

40 <td width="15%"> 作 者 <td> 

41 <td width="8%"> 定 价 ( 元 )</td> 

42 <td width="8%"> 借 阅 次 数 </td> 

43 </t> 

44 <?php 

45 $sql=mysql_query("select * from (select bookid, count(bookid) as degree from tb_borrow 
group by bookid) as 


46 borr join (select b.*, c.name as bookcasename, p.pubname, ttypename from tb_bookinfo 
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b left join 
47 tb_bookcase ¢ on b.bookcase=c.id join tb_publishing p on b.ISBN=p.ISBN join 
tb_booktype t on b.typeid=tid 
48 where b.del=0) as book on borr.bookid=book.id order by borr.degree desc limit 10"); // 提 
交 数 据 库 查询 命令 


49 Sinfo=mysql_fetch_array($sqD); // 遍 历数 据 库 

50 Si=1; 

51 dof 

S52 ?> | 
53 <tr> | 
54 <td height="25" align="center"><?php echo $i;?></td> | 
和 <td style="padding:Spx;">&nbsp;<?php echo Sinfo[barcodel;?> </td> | 
56 <td style="padding:Spx;"><?php echo Sinfo[bookname];?></td> | 
ST <td style="padding:Spx;"><?php echo Sinfo[typename];?></td> | 
58 <td align="center">&nbsp;<?php echo Sinfo[bookcasename];?> </td> | 
59 <td align="center">&nbsp;<?php echo Sinfo[pubname];?></td> | 
60 <td align="center"><?php echo Sinfo[author];?></td> | 
61 <td align="center"><?php echo Sinfo[price];?></td> | 
62 <td align="center"><?php echo Sinfo[degree];?></td> | 
63 </tr> | 
64 <?php | 
65 Si=Si+l; | 
66 jwhile(Sinfo=mysql_fetch_array($sqD); | 
67 ?> | 
68 </table></td> | 
69 </tr> | 
70 <t> | 
| <td height="19" background="Images/main booksort 2.gif'>&nbsp;</td> | 
?2 </t> | 
73 </table> | 
74 </td> | 
75 </tr> | 
76 </table> | 
7 <p>&nbsp:</p></td> | 
78 </t> | 
79 </table></td> | 
80 ”</t> | 
81 </table> | 
82 <?php include("copyright.php"); ?></td> | 
83 </t> | 
84 -</table> | 
85 </html> | 


说 明 : 

在 附录 中 不 要 给 代码 添加 任何 效果 ， 也 不 需要 体现 过 多 注释 ， 只 需要 在 关键 代码 位 置 
给 出 文字 说 明 即 可 。 附 录 中 的 程序 尽量 保证 代码 工整 、 清 晰 易 读 、 层 次 分 明 ， 如 果 所 需要 
说 明 的 程序 不 能 在 一 个 附录 中 全 部 体现 ， 则 需要 重新 添加 附录 并 在 附录 标题 前 添加 A、B 
(大 写 英文 字母 ) 或 TI (大 写 罗马 数字 ) 以 示 区 别 。 
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NS 
7.15.2 ”附录 B 子 程序 (BookBorrow.php 代码 ) 


01 <?php session start():?> 


28 <?php include("navigation.php"):2> 
29 <table width="776" border="0" cellspacing="0" cellpadding="0" align="center"> 


02 <html> 
供 站 03 <head> 
04 <link href="CSS/style.css" rel="stylesheet"> 
Note 05 <script language="javascript"> 

! 06 function checkreader(form){ 
| 07 if(form.barcode.value—""){ 
| 08 alert(" 请 输入 读者 条 形 码 !1");form.barcode.focus(:return; 
| 09 } 
| 10 form.submitO: 
| 11 } 
| 12 function checkbook(fonm){ 
| 13 if(form.barcode.value—""){ 
| 14 alert(" 请 输入 读者 条 形 码 !1");form.barcode.focus():return; 
| 15 } 
| 16 if(form.inputkey.value—""){ 
| 17 alert(" 请 输入 查询 关键 字 !");form.inputkey.focusO:return; 
| 18 } 
| 19 
| 20 if(form.number.value-form.borrowNumber.value<=0){ 
| 列 alert(" 您 不 能 再 借阅 其 他 图 书 了 !"):return; 
| 22 } 
| 23 form.submitO); 
| 24 } 
| 25 </script> 
| 26 </head> 
| 27 <body> 


30 <tr> 

Sl <td valign="top" bgcolor="#FFFFFF"> 

32 <table align="center" cellpadding="0" cellspacing="0" bgcolor="#FFFFFF" class="table 
Border gray"> 

33 <tr> 

34 <td align="left" valign="top" style="padding:Spx:"> &nbsp: 

35 ”<span class="word_orange">&nbsp; 当 前 位 置 : 图 书 借 还 &gt; 图 书 借阅 &gt;&gt;&gt; 
</span> 

36 <table width="100%" border="0" cellpadding="0" cellspacing="0"> 

3 <?php 

38 include("conn/conn.php"); 

39 $sql=mysql_query("select r.*, t.name as typename, t.number from 


40 thb_reader r left join tb_readerType t on r.typeid=t.id where r.barcode="".$ POST 
[barcode].""™"); 


41 Sinfo=mysql fetch_array($sqD); 
42 x 

43 <!-- 中 间 省 略 部 分 代码 -> 

44 <tr> 
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45 <td valign="top" bgcolor="#D2E5F1" style="padding:5px"> 
46 <table bordercolor="#FFFFFF" bordercolorlight="#FFFFFF" bordercolordark="#9ECFEE" 
bgcolor="#FFFFFF"> 


47 <tr align="center" bgcolor="#E2F4F6"> 

48 <td width="29%" height="25"> 图 书 名称 </td> 
49 <td width="12%"> 借 阅 时 间 </td> 

50 <td width="14%"> 应 还 时 间 </td> 

51 <td width="17%"> 出 版 社 </td> 

By <td width="14%"> 书 架 </td> 

53 <td colspan="2"> 定 价 (元 )</td> 

54 </t> 

55 <?php 


56 。 Sreaderid=Sinfolid]; | 

7 S$sqll=mysql_query("'select r.*, borr.borrowTime, borr.backTime, book.bookname, ， 
book.price, 

58 pub.pubname, bc.name as bookcase from tb_borrow as borr join tb_bookinfo as book on 


book. 
59 id=borr.bookid join tb_publishing as pub on book.ISBN=pub.ISBN join tb_bookcase as 
be on 
60 book.bookcase=bc.id join tb_reader as r on borr.readerid=r.id | 
61 Where borrreaderid='Sreaderid' and borr.ifback=0"); | 
62 /l/$sql=mysql_query("'select tdays from tb_bookinfo b left join tb_booktype t on | 
63 b.typeid=t.id where b.barcode="".$_POST[barcode]."""); | 
64 Sinfol=mysql_fetch_array($sql1); | 
65 SborrowNumber=mysql_num_rows($sqll); // 获 取 结 果 集 中 行 的 数目 | 
66 do{f | 
67 ?> | 
68 <t> | 
69 <td height="25" style="padding:5px:">&nbsp:<?php echo $infol | 
[bookname]:?></td> | 
70 <td style="padding:5px:">&nbsp:<?php echo $infol [borowTime]:?> | 
</td> | 
71 <td style="padding: 5px:">&nbsp:<?php echo $infol [backTime]:?> | 
</td> | 
72 <td align="center">&nbsp;<?php echo S$infol [pubname];?> | 
</td> | 
73 <td align="center">&nbsp:<?php echo $infol [bookcase]:?> | 
</td> | 
74 <td width="14%" align="center">&nbsp;<?php echo $infol[price]:?> | 
</td> | 
75 </tr> | 
76 <?php | 
77 }while(Sinfol=mysql_fetch_array($sql1)); | 
78 ?> | 
79 <input name="borrowNumber" type="hidden" id="borrowNumber" value="<?php echo | 
$borowNumber: ?>"> | 
80 </table></td> | 
81 </tr> | 
82 </table></td> | 
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83 </tr> 

84 <tr> 

85 <td height="19" background="Images/main booksort 2.gif'>&nbsp;</td> 
86 </tr> 

87 </form> 

88 <?php 

89 if($ POST["inputkey"]!=""){ // 判 断 是 否 获取 提交 键 
90 $f=$ POST["f"]; // 获 取 传 递 值 


91 Sinputkey=trim($_POST!["inputkey"]); 

92 Sbarcode=$_POST["barcode"]; 

3 Sreaderid=$_POST["readerid"]; 

94 SborrowTime=date('Y-m-d'); 

95 SbackTime=date("Y-m-d"，(timeQ+3600*24*30)); // 归 还 图 书 日 期 为 当前 日 期 +30 天 期 限 
96 Squery=mysql_query("select * from tb_bookinfo where $f='Sinputkey""); 


97 Sresult=mysql fetch_array(Squery); // 检 索 图 书信 息 是 否 存在 
98 if(Sresult=——false){ 

99 echo "<script language='javascript'>alert(' 该 图 书 不 存在 ! ); 

100 window.location.href='"bookBorrow.php?barcode=S$barcode';</script>"; 

101 } 

102 else{ 


103 Squeryl=mysql query("select r.*, borr.borrowTime, borr.backTime, book.bookname, 
book.price, 

104 pub.pubname, bc.name as bookcase from tb_borrow as borr join tb_reader as r on 
borr.readerid=r.id join 

105 tb_bookinfo as book on book.id=borr.bookid join tb_publishing as pub on 
book.ISBN=pub.ISBN join 

106 tb_bookcase as bc on book.bookcase=bc.id where borrbookid=Sresult[id] and 

107 ”borr.readerid=Sreaderid and ifback=0'");// 检 索 该 读者 所 借阅 的 图 书 是 否 与 再 借 图 书 重复 

108 ”Sresult1=mysql_fetch_array($queryl; 


109 if(Sresult1l==true){ /如 果 借 阅 的 图 书 已 被 该 读者 借阅 ， 那 么 提示 不 能 重复 借阅 

110 echo "<script language='javascript'>alert(' 该 图 书 已 经 借阅 ! ); 

lll window.location.href='bookBorrow.php?barcode=$barcode';</script>"; 

112 } 

113 elsef /否则 ， 完 成 图 书 借阅 操作 

114 Sbookid=Sresult[id]; 

Js mysql_query("insert into tb_borrow(readerid,bookid,borrowTime,backTime, 
operator,ifback) 

116 values('$readerid', 'Sbookid', 'SborrowTime', 'SbackTime', '$_SESSION[admin_name]', 
0"); 

117 echo "<script language='javascript'>alert(' 图 书 借阅 操作 成 功 ! ); 

118 window.location.href='"bookBorrow.php?barcode=Sbarcode';</script>"; 

Te 

120 } 

2 

122 ?> 

123 </table></td> 

124 </tr> 

125 ”</table> 

126 <2php include("copyright.php");?></td> 
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127 </tr> 
128 </table> 
129 </body> 
130 “<html> 
说 明 ， | 全 J 
附录 中 的 代码 ， 可 以 根据 毕业 设计 (论文 ) 所 用 代码 的 实际 情况 适当 增 减 。 一 般 毕 业 


设计 (论文 ) 大 概 在 40 页 左右 ， 本 章 中 的 附录 并 没有 将 所 有 的 代码 展示 给 用 户 ， | | 


码 请 参阅 配套 资源 中 的 源 程序 。 


本 章 小 结 


本 章 通 过 模拟 撰写 图 书馆 管理 系统 的 毕业 设计 (论文 ) 来 向 读者 展示 毕业 设计 论文 ) 


的 基本 写作 步骤 。 通 过 学 习 ， 读 者 可 以 了 解 以 下 内 容 。 
(1) 毕业 设计 的 内 容 和 要 求 。 
(2) 如 何 撰写 开题 报告 。 
(3) 如 何 设计 毕业 论文 封面 。 
(4) 如 何 撰写 毕业 论文 摘要 。 
(5) 如 何 设计 毕业 论文 目录 。 


(6) 如 何 撰写 论文 ， 从 绪论 、 开 发 工具 、 需 求 分 析 、 数 据 库 设计 到 系统 设计 ， 再 到 


系统 功能 实现 。 
(7) 如 何 编写 结论 。 
(8) 如 何 编写 参考 文献 。 
(9) 如 何 编写 致谢 和 附录 。 


说 明 : 


完整 的 毕业 设计 论文 。 
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由 于 本 章 讲解 的 重点 是 如 何 完成 毕业 设计 的 制作 ， 所 以 没有 对 项 目的 具体 功能 实现 进 
行 系统 的 讲解 。 但 是 在 本 书 的 配套 资源 中 提供 了 该 项 目的 完整 源 代码 ， 同 时 还 配备 了 一 份 | 


第 /o 1 章 


电子 商务 网 站 


( PHP+MySQL 5.0 实现 ) 
自学 视频 、 源 程序 : 配套 资源 \mAN&N\ 


随 着 信息 时 代 的 发 展 ， 国 际 电子 商务 市 场 已 成 为 发 展 最 快 的 市 场 之 一 ， 随 
着 国内 结算 体系 的 逐渐 完善 并 与 世界 接轨 ， 电 子 商务 已 经 在 全 世界 范围 内 迅速 


_ -删除 的 内 容 : 
EC RR RR i 


I 开题 报告 的 填写 

WI 封面 设计 原则 

了 目录 的 编排 方法 

PI 毕业 设计 的 中 /英文 摘要 范例 
WI 毕业 设计 整体 结构 

WI 毕业 设计 正文 书写 范例 


第 B 章 电子 商务 网 站 (PHP+MIySQL 5.0 实现 ) 


五 


8.1 设计 说 明 


8.1.1 毕业 设计 论文 ) 主要 内 容 | 好 


毕业 设计 是 一 份 由 即将 毕业 的 学 生 提 供 的 研究 性 报告 ， 该 报告 是 在 指定 教师 的 指导 县 < 
下 ， 进 行 初步 科学 研究 所 取得 成 果 的 科学 表述 ， 也 可 以 是 一 篇 在 教师 的 指导 下 集体 或 个 人 | 
阅读 文献 的 总 结 。 一 份 完整 的 毕业 设计 至 少 应 包括 以 下 内 容 。 

加 ”开题 报告 开题 报告 一 般 需 要 学 生 结合 自身 信息 来 填写 所 选 毕业 设计 论文 ) 题 | 
目 、 个 人 信息 、 选 题 意义 和 内 容 等 信息 ， 是 一 篇 综合 性 的 报告 。 

回 ”中 /英文 文献 ,与 所 选 毕业 设计 技术 相关 的 科技 类 文字 或 说 明 。 

加 ”毕业 设计 封面 (可 选 ) :主要 包括 具有 概括 性 文字 的 选 文 标题 以 及 学 生 姓名 、 指 
导 教师 等 信息 。 

回 ”中 / 黄 文 摘要 : 设计 〈 论 文 ) 的 中 文摘 要 一 般 为 200~300 字 ， 摘 要 是 一 篇 具有 独 | 
立 性 和 完整 性 的 短文 。 设 计 〈 论 文 ) 英文 摘要 的 内 容 与 中 文摘 要 相同 。 | 

回 ”设计 《论文 ) 目录 : 目录 应 独立 成 页 ， 包 括 设计 论文 ) 中 全 部 章 、 节 的 标题 及 | 
页 码 。 | 

加 ”设计 (论文 ) 正文 : 正文 是 毕业 设计 (论文 ) 的 主体 ， 着 重 反映 研究 工作 范畴 和 
研究 方法 ， 并 将 调查 、 研 究 中 所 获得 的 材料 和 数据 进行 加 工整 理 和 分 析 研 究 ， 提 
出 论点 。 

回 ”附录 (可 选 ) : 一 般 由 论文 作者 提供 与 论文 内 容 相关 的 图 片 、 程 序 代码 等 信息 。 

回 ”参考 文献 : 毕业 设计 作者 在 撰写 设计 〈 论 文 ) 时 所 参考 的 相关 书籍 、 报 纸 、 杂 志 
等 文献 作品 。 

回 ”致谢 ， 对 指导 教师 和 给 予 指导 或 协助 完成 设计 《论文 ) 工作 的 组 织 和 个 人 表示 感 
谢 。 内 容 应 简洁 明了 、 实 事 求 是 ， 避 免 落 入 俗套 。 


8.1.2 ”毕业 设计 〈 论 文 ) 要 求 | 


电子 商务 网 站 的 设计 要 求 是 : 根据 当前 电子 商务 的 需求 考察 、 分 析 ， 并 结合 电子 商务 | 
市 场 的 发 展 趋势 ， 以 B/S 模式 为 基础 ， 独 立 开发 设计 一 个 电子 商务 网 站 系统 ， 并 撰写 毕业 | 
设计 论文 )。 

毕业 设计 论文 ) 各 部 分 的 一 般 顺序 为 中 英文 题目 、 中 文摘 要 、 英 文摘 要 、 目 录 、 正 
文 、 参 考 文献 、 致 谢 、 附 录 。 主 要 要 求 如 下 : 

回 ”正文 内 容 包 括 绪论 (引言 ) 、 主 体 部 分 和 结论 3 个 重要 部 分 。 正 文 要 求 论点 正确 、 

推理 严谨 、 数 据 可 靠 、 文 字 精 练 、 条 理 分 明 。 

回 ”正文 章节 序号 ， 第 一 章 、1.1、1.1.1， 第 二 章 、2.1、2.1.1…… 

回 “正文 字数 要 求 : 10 000 一 15 000 字 。 

加 ”参考 文献 说 明 : 列 出 引用 的 主要 文献 。 为 了 反映 文稿 的 科学 依据 ， 尊 重 他 人 的 研 | 
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gm 人 Be 项 目 业 例 分 析 


究 成 果 以 及 向 读者 提供 有 关 信息 的 出 处 ， 正 文中 应 按 顺 序 在 引用 参考 文献 处 的 文 

| 字 右 上 角 用 “ 口 ” 标 明 ，“ 口 ”中 的 序号 应 与 参考 文献 列表 中 序号 一 致 

”加 ”参考 文献 数量 不 少 于 4 篇， 其 中 外 文 参考 文献 不 少 于 1 篇。 

”加 ”参考 文献 主要 包括 连续 出 版 物 〈 期 刊 ) 、 专 车 、 专 利文 献 、 国 际 和 国家 标准 以 及 
报纸 文章 等 。 

回 ”格式 要 求 ; 根据 相应 规定 更 改 毕业 设计 《论文 ) 格式 。 


8.2 填写 开题 报告 


开题 报告 是 由 毕业 论文 作者 根据 论文 题目 填写 的 报告 说 明 。 其 大 体格 式 和 主要 内 容 如 


| XX 师范 大 学 本 科 毕 业 论文 (设计) 开题 报告 
| 基于 PHP 的 电子 商务 网 站 系统 设计 


| 计算 机 科学 与 技术 
| 学 和 4 姓名 | xxx | 指教 策 | XXX (职称 ) 

本 选 题 的 意义 及 在 国内 外 的 发 展 状况 : 

电子 商务 是 一 项 全 新 的 经 济 方式 ， 它 的 产生 和 发 展 必 将 对 世界 经 济 产生 重大 的 影响 。 电 子 商 务 正 
在 深刻 地 改变 着 经 济 、 市 场 和 产业 结构 ; 改变 着 产品 、 服 务 及 其 流动 ; 改变 着 消费 者 的 价值 和 行为 ; 
改变 着 就 业 和 劳动 力 市 场 。 对 一 个 企业 来 说 ， 电 子 商 务 是 一 种 新 的 经 营 手 段 。 随 着 网 络 和 电子 商务 的 
发 展 ， 当 越 来 越 多 的 企业 开始 以 电子 商务 的 方式 实现 管理 和 营销 时 ， 便 形成 了 一 个 电子 商务 的 经 营 和 
市 场 环境 ， 这 是 一 个 全 新 的 竞争 激烈 的 国际 化 市 场 。 为 适应 这 种 新 的 经 营 环境 ， 应 对 来 自 全 球 竞争 者 
的 挑战 ， 我 国 的 电子 商务 企业 和 开展 或 即将 开展 电子 商务 的 传统 企业 ， 除 要 选择 适合 自身 发 展 的 商业 
模式 外 ， 也 需要 建立 自己 的 电子 商务 网 站 系统 ， 以 提高 企业 的 竞争 力 。 

研究 内 容 : 

基于 PHP 的 电子 商务 网 站 系统 原理 设计 。 

基于 PHP 的 电子 商务 网 站 系统 程序 设计 。 

前 台 页 面 设计 和 软件 部 分 调试 。 

研究 方法 、 手 段 及 步骤 ; 

系统 流程 设计 : 针对 本 设计 要 求 并 配合 查阅 网 上 资料 ， 设 计 整 个 实现 流程 。 

原理 图 绘制 ， 应 用 绘图 软件 绘 出 原理 图 。 

前 台 页 面 设 计 : 应 用 Dreamweaver 软件 ， 结 合 JavaScript 语言 设计 前 台 界面 。 

后 台 程 序 编写 ; 根据 原理 图 要 求 编程 。 

前 台 页 面 和 后 台 程序 的 联合 调试 : 测试 已 经 完成 的 程序 ， 修 正 逻 辑 问题 及 语法 错误 。 

参考 文献 : 

[] 邹 天 思 ， 孙 鹏 .PHP 从 入 门 到 精通 [M] .北京 : 清华 大 学 出 版 社 ，2008. 

[2] 潘 凯 华 ， 分 天 思 .PHP 开发 实战 宝典 [M]. 北 京 : 清华 大 学 出 版 社 ，2010. 

[3] 邻 天 思 ， 潘 凯 华 ， 刘 中 华 .PHP 网 络 编程 自学 手册 [MJ]. 北 京 人 民 邮 电 出 版 社 ，2008. 

[和 ( 美 》Vasani.。 MySQL 完全 手册 [M]. 徐 小 青 ， 路 晓 村 等 译 . 北京 : 电子 工业 出 版 社 ，2004. 

[5] 潘 凯 华 等 .PHP 项 目 开发 案例 全 程 实录 [M]. 2 版 . 北京 : 清华 大 学 出 版 社 ，2011. 
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说 明 : 
每 所 学 校 的 开题 报告 的 布局 都 会 略 有 差别 。 不 过 ， 基 本 结构 大 体 相同 。 这 里 只 给 读者 
一 个 最 基本 的 格式 ， 具 体内 容 还 需要 根据 个 人 实际 情况 考虑 。 


83 封面 设计 


毕业 设计 的 封面 要 遵行 简洁 、 大 方 、 得 体 的 设计 思想 ， 内 容 上 清晰 、 明 了 ， 文 字 有 概 
括 性 。 毕 业 设计 的 题目 不 宜 超过 25 个 字 ， 另 外 ， 标 题 中 尽量 不 要 用 英文 缩写 词 。 优 秀 的 
毕业 设计 封面 不 但 可 以 给 审阅 教师 耳目 一 新 的 感觉 ， 也 可 以 向 答辩 委员 会 清晰 地 展示 出 自 


己 的 论文 选 题 。 大 多 数学 校对 毕业 设计 的 封面 没有 限制 性 要 求 ， 所 以 ， 具 体 的 封面 设计 还 | 


需要 读者 根据 自身 的 实际 情况 而 定 ， 这 里 只 给 出 最 基本 的 封面 样式 ， 以 供 读者 参考 。 本 章 
毕业 设计 的 封面 样式 如 图 8.1 所 示 。 


区 范 大 学 
毕业 设计 


基于 PHP 的 电子 商务 网 站 实现 
The Design and Implementation of 
E-Commerce WebSite Based on PHP 


系 ” 别 : 信息 工程 

专业 名 称 : 计算 机 科学 与 技术 
学 生 姓名 : 李 晶 

指导 教师 : 潘 攀 ( 夯 诅 授 ) 
完成 时 间 : 2011 年 ?月 


图 8.1 毕业 设计 封面 
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84 书写 摘要 


毕业 设计 的 第 一 页 和 第 二 页 分 别 为 中 文摘 要 与 英文 摘要 。 摘 要 书写 必须 完全 遵循 英汉 
对 应 的 关系 ， 即 英文 摘要 详 成 的 中 文 要 与 中 文摘 要 内 容 相同 。 另 外 ， 摘 要 是 一 篇 具有 独立 
性 和 完整 性 的 短文 ， 文 字 要 精炼 ， 应 扼要 叙述 本 设计 的 研究 目的 和 内 容 、 主 要 特点 和 成 果 
及 结论 性 意见 。 摘 要 中 不 宜 使 用 公式 、 图 表 ， 不 标注 引用 文献 编号 ， 避 免 将 摘要 写成 目录 
式 的 内 容 介绍 。 为 了 便于 文献 检索 ， 应 在 摘要 下 方 另 起 一 行 注 明 本 文 的 关键 词 。 在 英文 摘 
要 中 同样 需要 提供 对 应 的 英文 关键 词 。 关 键 词 应 采用 能 覆盖 设计 论文 ) 主要 内 容 的 通 
用 技术 词 条 《参照 相应 的 技术 术语 标准 )， 一 般 为 3 一 5 个 ， 并 按 词 条 的 外 延 层次 从 大 
到 小 进行 排列 。 下 面 分 别 向 读者 展示 电子 商务 网 站 毕业 设计 〈 论 文 ) 的 中 英文 摘要 。 

1， 中 文摘 要 

随 着 互联 网 技术 的 迅猛 发 展 ， 在 市 场 经 济 下 企业 交易 越 来 越 趋向 于 多 元 化 ， 而 客观 经 
济 环境 的 变化 ， 使 企业 在 开展 电子 商务 方面 势 在 必 行 。 电 子 商 务 不 仅仅 适用 于 大 企业 ， 对 
中 小 企业 也 非常 有 利 ， 更 是 为 中 小 企业 与 大 企业 的 竞争 提供 了 很 好 的 机 会 和 平台 。 中 小 企 
业 作 为 各 国 经 济 的 基础 和 社会 经 济 中 最 为 活跃 的 因素 ， 成 为 社会 经 济 储蓄 发 展 和 繁荣 稳定 
的 重要 保障 。 与 此 同时 ， 电 子 商务 作为 新 经 济 时 代 下 的 产物 ， 已 经 成 为 众多 企业 关注 和 利 
用 的 焦点 。 发 展 电子 商务 将 是 中 小 企业 在 未 来 取得 长 足 发 展 的 必由之路 。 本 文 阐述 了 如 何 
利用 PHP 开发 电子 商务 网 站 ,从 而 使 中 小 企业 发 展 电子 商务 , 在 激烈 的 市 场 竞 争 中 立 于 不 
败 之 地 。 

关键 词 ， 电 子 商 务 ” 中 小 企业 发 展 PHP 

2. 英文 摘要 ( Abstract ) 


With the rapid development of internet, business transactions are increasingly in favor of 
diversification. What's more, the changes from objective economic environment stimulate 
corporations to promote e-business inevitably. It is not only applicable for large organizations, 
but also for small and medium-sized enterprises, which provides both of them with a fine 
platform in competition. As the economic foundation of a nation and the most active element in 
social economy, SME(small and medium-sized enterprises) guarantee socio-economic savings 
development, prosperity and stability. In the meantime, generated in this new economic era, 
e-business has been wildly noted and exploited by numerous enterprises, which will definitely 
lead SME to the future success.This text introduced the process of e-commerce systems 
developing with PHP, in order to establish themselves in an unassailable position in this violent 
market competition. 


Keywords: E-commerce Small and midium-sized enterprises Development PHP 
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元 
dc 
85 编排 日 录 | 

| 

目录 是 整个 毕业 设计 内 容 的 索引 ， 其 作用 主要 为 审阅 人 员 展 示 毕 业 设 计 的 整体 架构 和 | 


标题 内 容 , 毕业 设计 目录 一 般 应 独立 成 页 ,其 主要 包括 设计 中 全 部 章 、 节 的 标题 及 页 码 ( 包 | 全 一 
括 参考 文献 、 致 谢 )。 下 面 给 出 目录 的 具体 样式 。 | 


1.1 本 课题 的 开发 背景 及 意义 
1.1.1 设计 的 背景 
1.1.2 开发 意义 

1.2 课题 研究 内 容 … 

1.3 设计 组 织 结构 ………… 

第 2 章 开发 工具 及 相关 技术 


4 | -列队 的 内 容 : 
带 格式 的 : 缩 过 : 首 生 
4 字符 


2.1.1 Zend Studio 简介 - 
2.1.2 ”EclipsePHP Studio 
2.1.3 PHP Designer… 
2.1.4 PHPEdit … 


2.2.1 AppServ 集成 环境 - 
2.2.2 ”WAMP 集成 环境 
2.2.3 XAMPP 集成 环境 … 


4 
2.3.2 JavaScript 语言 


2.3.3 CSS 概述 


"| -出 除 的 内 容 


的 : 缩 进 : 首 行 
We 


2.4.1 B/S 结构 的 优点 … 
2.4.2 ”B/S 结构 的 缺点 


FN 


第 3 章 
3.1 必要 性 与 可 行 性 分 析 
3.2 系统 需求 … 
3.3 功能 需求 … 
3.4 系统 性 能 要 求 

第 4 章 系统 数据 库 设计 
4.1 数据 库 理论 基础 … 
4.2 系统 实体 E-R 图 … 


4 

4 

3 

5 

5 

人 | .< 【下 的 内 容 

7 | “| 和 4 
| 
8 

8 

8 

8 

全 

9 
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43 系统 数据 表 设计 - 
第 5 章 系统 设计 
5.1 系统 实现 关系 图 
5.2 系统 功能 模块 设计 


| 5.2.1 系统 的 功能 模块 


Ge 5.2.2 系统 功能 模块 特点 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
j 


ne 23 
6.1 商品 展示 模块 设计 … 
6.1.1 推荐 商品 展示 … 
6.1.2 最 新 商品 展示 … 
6.1.3 热门 商品 展示 
6.1.4 商品 分 类 展示 
6.1.5 查看 商品 详细 信息 … 
6.2 ”购物 车 模块 设计 
6.2.1 添加 商品 至 购物 车 
6.2.2 ”查看 购物 车 … 
6.2.3 ”操作 购物 车 
6.3 ”搜索 模块 设计 …… 


6.4 订单 管理 模块 设计 … 
6.4.1 查看 订单 … 
6.4.2 ”执行 订单 
6.4.3 打印 订单 … 
6.4.4 查找 订单 

6.5 商品 管理 模块 … 


6.5.1 添加 商品 信息 
6.5.2 ”修改 商品 信息 -42 


6.5.3 ”删除 商品 信息 


第 7 章 结论 43 
参考 文献 -44 
致谢 = -45 
附录 A 主 程序 46 


说 明 : 
以 上 毕业 设计 目录 中 涉及 的 内 容 和 页 码 ， 请 读者 根据 自身 的 实际 情况 制定 。 这 里 仅 为 
| 读者 提供 一 个 参考 。 
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1 

8.6 绪论 | 

| 
绪论 主要 用 于 说 明 选 题 背景 、 目 的 及 意义 ， 国 内 外 现状 和 应 解决 的 主要 问题 。 会 内 
8.6.1 本 课题 的 开发 背景 及 意义 Ras 
MNote 


电子 商务 是 一 项 全 新 的 经 济 方式 ， 它 的 产生 和 发 展 必 将 对 世界 经 济 产生 重大 的 影响 。 | 
电子 商务 正在 深刻 地 改变 着 经 济 、 市 场 和 产业 结构 ， 改 变 着 产品 、 服 务 及 其 流动 ， 改 变 着 | 
消费 者 的 价值 和 行为 ， 改 变 着 就 业 和 劳动 力 市 场 。 对 一 个 企业 来 说 ， 电 子 商务 是 一 种 新 的 | 
经 营 手段 。 随 着 网 络 和 电子 商务 的 发 展 ， 越 来 越 多 的 企业 开始 以 电子 商务 的 方式 实现 管理 | 
和 营销 的 时 候 ， 便 形成 了 一 个 电子 商务 的 经 营 和 市 场 环 境 ， 这 是 一 个 全 新 的 竞争 激烈 的 国 
际 化 市 场 。 为 适应 这 种 新 的 经 营 环境 ， 应 对 来 自 全 球 竞争 者 的 挑战 ， 我 国 的 电子 商务 企业 
和 开展 或 即将 开展 电子 商务 的 传统 企业 ， 除 了 要 选择 适合 自身 发 展 的 商业 模式 外 ， 也 需要 
建立 自己 的 电子 商务 网 站 系统 ， 并 通过 互联 网 宣传 ， 以 提高 企业 的 竞争 力 。 


8.6.2 ”课题 研究 内 容 


本 设计 主要 应 用 PHP 编程 、Web 开发 以 及 MySQL 数据 库 连 接 等 相关 知识 ， 利 用 动态 | 
网 页 开发 技术 ， 将 所 学 的 知识 用 于 实际 的 生活 中 ， 并 且 在 实际 的 生活 中 发 挥 其 主要 功能 并 
获得 效益 ， 本 设计 内 容 包 括 以 下 功能 模块 : 

回 ”商品 展示 模块 : 主要 包括 推荐 商品 展示 、 最 新 商品 展示 、 特 价 商品 展示 、 商 品 分 
类 展示 以 及 查看 商品 详细 信息 等 功能 。 
购物 车 模块 : 主要 包括 添加 商品 至 购物 车 、 查 看 购物 车 、 修 改 购物 车 中 商品 数量 、| 
移 除 购物 车 内 指定 商品 和 清空 购物 车 等 操作 。 | 
搜索 模块 ， 主 要 包括 简单 搜索 和 高 级 搜索 两 种 搜索 方式 。 | 
订单 管理 模块 : 主要 包括 查看 订单 、 执 行 订 单 、 打 印 订 单 和 查找 订单 等 操作 。 | 
商品 管理 模块 ， 主 要 包括 添加 商品 信息 、 修 改 商品 信息 和 删除 商品 信息 等 操作 。 


回 


回回 加 


说 明 : | 
整个 电子 商务 网 站 结构 按 功能 可 以 划分 为 前 台 用 户 系 统 和 后 台 管 理 系统 。 


8.6.3 设计 组 织 结构 


本 毕业 设计 的 主体 主要 分 为 6 大 部 分 。 
加 第 1 部 分 : 即 绪论 部 分 ， 主要 介绍 毕业 设计 论文 ) 的 开发 背景 和 意义 、 研 究 内 
容 、 组 织 结构 等 内 容 。 
回 第 2 部分: 主要 介绍 本 毕业 设计 中 所 用 到 的 开发 软件 、 运 行 环境 以 及 开发 过 程 所 
需要 的 结构 体系 等 要 素 。 
第 3 部 分 : 介绍 系统 的 可 行 性 分 析 以 及 功能 需求 等 内 容 。 
第 4 部分: 介绍 数据 库 的 基本 数据 表 结 构 设 计 。 
。343 。 ~ 


加 加 


人 Bi 项 目 业 例 分 析 


第 5 部 分 : 根据 需求 分 析 整 个 系统 的 构架 并 陈列 主要 功能 模块 。 
| 回 第 6 部 分 : 详细 讲解 各 功能 模块 的 实现 过 程 和 运行 结果 。 


8.7 开发 工具 及 相关 技术 


Xe 8.7.1 开发 工具 


PHP 是 一 种 开放 性 的 编程 语言 ， 这 也 导致 了 开发 环境 没有 强 而 权威 的 支持 ， 选 择优 秀 
的 开发 工具 就 显得 尤为 重要 。 
1. Zend Studio 


Zend Studio 是 Zend Technologies 开发 的 PHP 语言 集成 开发 环境 (Integrated 
Development Environment，IDE)， 也 支持 HTML 和 JS 标签 ， 但 只 对 PHP 语言 提供 调试 支 
持 。 因 为 是 同一 个 公司 的 产品 ， 所 以 提供 的 Zend Framework 方面 的 支持 比 其 他 软件 好 。 
Zend Studio 5.5 系列 后 , 官方 推出 利用 Eclipse 平台 、 基 于 PDT 的 Zend Studio for Eclipse 6.0， 
之 后 的 版 本 也 都 构建 于 Eclipse。 

Zend Studio 是 屡 获 大 奖 的 专业 PHP 集成 开发 环境 ， 具 备 功能 强大 的 专业 编辑 工具 和 
调试 工具 ,支持 PHP 语法 加 亮 显示 、 语 法 自动 填充 、 书 签 、 语 法 自动 缩 排 和 代码 复制 等 功 
能 ， 内 办 一 个 强大 的 PHP 代码 调试 工具 , 支持 本 地 和 远程 两 种 调试 模式 ， 支 持 多 种 高 级 调 
试 功能 。 

2. EclipsePHP Studio 


EclipsePHP Studio (简称 EPP) 是 一 个 大 型 PHP 项 目 开 发 编 详 器 , 基于 Eclipse 底层 开 
发 而 来 ， 并 且 集 成 了 JDK， 免 除了 安装 配置 的 麻烦 ， 一 次 安装 即 可 使 用 ， 无 需 配 置 。 此 编 
详 器 为 PHP 编译 器 ， 辅 助 PHP 代码 的 开发 和 调试 ， 集 成 了 代码 高 亮 、 函 数 跟 踪 和 时 时 纠 
错 等 功能 。 同 时 还 增加 了 协作 开发 版 本 服务 器 功能 SVN 和 CVS。 内 区 浏 览 器 可 以 在 调试 
简单 代码 时 浏览 。 不 仅 支持 PHP ， 也 支持 其 他 网 络 语言 ， 如 HIML、XHTML、XML、 
CSS 和 JavaScript、Java、Perl 和 Python 等 。 


3. PHP Designer 


PHP 是 一 种 能 嵌入 到 其 他 网 络 编程 语言 的 技术 。PHP Designer 不 仅 支持 php， 也 支持 
其 他 网 络 语言 ， 如 HIML、XHTM、XML、CSS 和 JavaScript、Vbscript、Java、C#、Perl 
和 Python 等 。 

由 于 互联 网 上 具有 丰富 的 免费 资源 ， 越 来 越 多 的 人 热衷 于 对 PHP 的 学 习 ，MPS PHP 
Designer 是 针对 PHP 网 页 的 编写 所 设计 的 程序 ， 它 内 建 一 系列 的 指令 码 、PHP4 原始 码 数 
据 库 、 语 法 高 亮度 显示 功能 、FTP 客户 端 等 ,无 论 是 PHP 网 页 设计 高 手 ， 还 是 刚 入 门 的 新 
手 ， 都 可 以 使 用 这 套 软件 来 帮助 开发 者 设计 网 页 程序 (SQL、HTML 亦 支持 )。 

PHP Designer 7.0 支持 PHP 中 用 户 最 喜欢 的 框架 ， 也 支持 任何 流行 的 JavaScript 框架 ， 
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如 jQuery 的 全 雅虎 民 库 、ExtJS 原型 和 MooTools。 
最 新 版 PHP Designer 2008， 是 完整 的 集成 开发 环境 ， 无 论 对 于 PHP 初学 者 还 是 专业 
发 人 员 ， 均 对 用 户 提高 自身 的 编程 技能 有 很 大 帮助 。 


4. PHPEdit 到 


PHPEdit 是 一 款 Windows 下 优秀 的 PHP 脚本 IDE (集成 开发 环境 )。 该 软件 为 快速 、 苇 2 
便捷 地 开发 PHP 脚本 提供 了 多 种 工具 ， 其 功能 包括 语法 关键 词 高 亮 ; 代码 提示 、 浏 览 ; 集 | 
成 PHP 调试 工具 ; 帮助 生成 器 ， 自 定义 快捷 方式 ，150 多 个 脚本 命令 ;键盘 模板 ; 报告 生 | 
成 器 ;快速 标记 ， 插件 等 。 | 

来 自 WaterProof Software 的 PHPEdit 感觉 像 是 应 用 于 PHP 的 Microsoft msdev 环境 。 
PHPEdit 是 仅 用 于 Windows 的 IDE， 很 容易 设置 。 它 甚至 还 有 PHP 的 版 本 。 在 PHP、CSS 
和 HTML 的 代码 智能 方面 做 得 很 好 ， 但 是 却 不 提供 对 JavaScript 代码 的 智能 支持 。 为 了 便 
于 部 署 ，PHPEdit 可 以 连接 到 CVS、Subversion 以 及 FTP 和 它 自己 专 有 的 ezDeployment 
系统 。 除 了 代码 智能 特性 ， 为 了 加 速 开发 ， 这 款 IDE 有 一 个 极 好 的 代码 示例 整体 模板 库 ， 
用 户 可 以 向 库 里 添加 内 容 。 


8.7.2 ”运行 环境 | 


1，AppServ 集成 环境 

AppServ 是 PHP 网 页 架 站 工具 组 合 包 , 作者 将 一 些 网 络 上 免费 的 架 站 资源 重新 包装 成 
单一 的 安装 程序 ， 以 方便 初学 者 快速 完成 架 站 ，AppServ 所 包含 的 软件 有 Apache、Apache 
Monitor、PHP、MySQL、phpMyAdmin 等 。 如 果 用 户 的 本 地 机 器 没有 安装 过 PHP、MySQL | 
等 系统 ， 那 么 用 该 软件 可 以 让 用 户 迅速 搭 建 完整 的 PHP 运行 环境 。 


2. WAMP 集成 环境 


WAMP 是 多 个 词 的 缩写 , 即 Windows 下 的 Apache+Mysql+Perl/PHP/Python, 它 是 一 组 
常用 来 搭建 动态 网 站 或 者 服务 器 的 开源 软件 ， 这 些 软件 本 身 都 是 相互 独立 的 程序 ， 但 是 因 
为 这 些 程序 在 应 用 PHP 技术 开发 Web 程序 的 过 程 中 常 被 放 在 一 起 使 用 ， 拥 有 了 越 来 越 高 | 
的 兼容 度 ， 共 同 组 成 了 一 个 强大 的 Web 应 用 程序 平台 。 | 

随 着 开源 潮流 的 莲 勃 发 展 ， 开 放 源 代码 的 LAMP 已 经 与 J2EE 和 .Net 商业 软件 形成 三 
足 易 立 之 势 ， 并 且 该 软件 开发 的 项 目 在 软件 方面 的 投资 成 本 较 低 ， 因 此 受到 整个 IT 界 的 

LAMP 是 基于 Linux、Apache、MySQL 和 PHP (PHP 有 时 可 用 Perl 或 Python 代替 ) 
的 开放 资源 网 络 开发 平台 。 这 个 术语 来 自 欧洲 ， 在 那里 ， 这 些 程序 常用 来 作为 一 种 标准 开 
发 环境 。 每 个 程序 在 所 有 权 里 都 符合 开放 源 代码 标准 : Linux 是 开放 系统 ， Apache 是 最 通 
用 的 网 络 服务 器 ， MySQL 是 带 有 基于 网 络 管理 附加 工具 的 关系 数据 库 ， PHP 是 流行 的 对 
象 脚本 语言 ， 它 包含 了 多 数 其 他 语言 的 优秀 特征 来 使 得 其 网 络 开发 更 加 有 效 。 开 发 者 在 
Windows 操作 系统 下 使 用 这 些 Linux 环境 里 的 工具 称 为 使 用 WAMP。 
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3. XAMPP 集成 环境 


| XAMPP (Apache+MySQL+PHP+Perl) 是 一 个 功能 强大 的 建 XAMPP 软件 站 集成 软件 
包 。 该 软件 包 原 来 的 名 字 是 LAMPP， 但 是 为 了 避免 引起 误解 ， 最 新 的 几 个 版 本 改名 为 
XAMPP。 它 可 以 在 Windows、Linux 和 Solaris 3 种 操作 系统 下 安装 使 用 ， 支 持 多 语言 ， 如 
英文 、 简 体 中 文 、 繁 体 中 文 、 韩 文 、 俄 文 、 日 文 等 。 

XAMPP 是 一 款 具 有 中 文 说 明 的 功能 全 面 的 集成 环境 ， 并 不 仅仅 针对 Windows， 而 是 
一 个 适用 于 Linux、Windows、Mac OS X 和 Solaris 的 易于 安装 的 Apache 发 行 版 。 软 件 包 
中 包含 Apache 服务 器 、MySQL、SQLite、PHP、Perl、FileZilla FTP Server、Tomcat 等 。 
默认 安装 开放 了 所 有 功能 ， 但 其 安全 性 有 问题 ， 需 要 进行 额外 的 安全 设 定 。 

总 的 来 说 ， 以 上 几 种 集成 环境 基本 上 都 可 以 满足 设计 配置 WAMP 环境 的 需要 ， 其 中 ， 
XAMPP 和 AppServ 各 种 组 件 较 全 ,但 文件 组 成 较 复杂 ,不 利于 初学 者 学 习 , 而 WAMP 有 具 
有 很 多 优点 ， 特 别 适 合 初学 者 使 用 。 


注意 : 
PHP 的 基础 环境 手动 配置 在 第 1 章 中 已 经 作 了 介绍 。 读者 也 可 以 根据 自己 的 想法 ， 将 
基础 环境 的 介绍 与 集成 环境 融合 在 一 起 。 本 小 节 重 点 介绍 PHP 常用 的 集成 环境 程序 。 


8.7.3 ”相关 技术 


1. PHP 的 工作 原理 及 相关 技术 


PHP (HyperText Preprocessor) 是 一 种 多 平台 无 颖 运行 的 服务 器 端 嵌 入 式 肢 本 语言 ， 
它 融 合 了 C、Java 和 Perl 等 编程 语言 ， 由 于 它 是 一 种 免费 的 软件 ， 具 有 自由 软件 的 性 质 ， 
且 版 本 更 新 速度 快 、 移 植 速度 快 ， 具 有 丰富 的 函数 库 功 能 ， 因 而 很 快 得 到 用 户 认 可 ， 特 别 
是 PHP 提供 加 密 函 数 库 ， 符 合 安全 性 较 高 的 电子 商务 网 站 的 要 求 ， 在 Apache 环境 下 构建 
的 PHP 网 站 已 经 成 为 当前 流行 的 Web 网 站 之 一 。 

PHP 能 够 作为 Apache Web 服务 器 的 模块 执行 ， 使 得 其 执行 效率 要 高 于 普通 的 CGI 程 
序 ， 而 且 能 比 CGI 或 Perl 更 快速 地 执行 动态 网 页 。 

使 用 者 如 果 创建 了 一 个 PHP 应 用 程序 ， 实 际 上 相当 于 创建 了 一 个 PHP 脚本 文件 。 在 
服务 器 将 输出 信息 发 送 到 客户 端 之 前 , 网 络 服务 器 会 率先 将 文件 中 的 PHP 语言 进行 加 工 处 
理 。 如 果 服 务 器 不 支持 PHP， 通 常情 况 下 ， 网 络 服务 器 会 直接 将 超 文本 文件 送 到 客户 的 浏 
览 器 上 以 表示 对 HTTP 的 要 求 作 出 应 答 ， 如 果 服 务 器 支持 PHP， 则 在 服务 器 响应 一 个 对 
PHP 文件 的 请 求 时 ， 会 进行 如 下 处 理 : 首先 在 一 个 PHP 文件 内 ， 标 准 的 HTML 编码 会 被 
直接 送 到 浏览 器 上 ， 而 内 嵌 PHP 程序 却 是 先 被 网 络 服务 器 解释 执行 。 如 果 是 标准 输出 ， 输 
出 信息 也 将 作为 标准 的 HTML 而 被 送 至 浏览 器 。 

PHP 可 以 安装 在 UNIX/Linux 环境 下 ， 也 可 以 安装 在 Windows 环境 下 。 目 前 网 站 使 用 
最 多 的 ， 也 是 最 理想 的 便 是 PHP+MySQL+Apache 基于 UNIX/Linux 下 的 服务 器 策略 。 


2.， JavaScript 语言 
JavaScript 是 一 种 解释 性 的 、 基 于 对 象 的 脚本 语言 (an interpreted, object-based scripting 
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language)。 


HTML 网 页 在 互动 性 方面 能 力 较 弱 ， 如 下 拉 菜 单 ， 用 纯 HTML 网 页 无 法 实现 ; 又 如 
验证 HTML 表单 Form) 提交 信息 的 有 效 性 时 ， 用 户 名 不 能 为 室 ， 密 码 不 能 少 于 4 位 ， 
邮政 编码 只 能 是 数字 等 ， 用 纯 HIML 网 页 也 无 法 实现 。 要 实现 这 些 功 能 ， 就 需要 用 到 
JavaScript。 


JavaScript 是 一 种 脚本 语言 ， 比 HTML 复杂 。 不 过 即便 先前 不 懂 编 程 ， 也 不 用 担心 ， 


因为 JavaScript 编写 的 程序 都 是 以 源 代码 的 形式 出 现 的 ， 也 就 是 说 ， 如 果 在 一 个 网 页 里 看 | 


到 一 段 比较 好 的 JavaScript 代码 ， 恰 好 可 以 用 得 上 ， 就 可 以 直接 复制 ， 然 后 放 到 自己 的 网 
页 中 去 。 正 因为 可 以 借鉴 、 参 考 优秀 网 页 的 代码 ， 所 以 让 JavaScript 本 身 也 变 得 非常 受 欢 
迎 ， 从 而 被 广泛 应 用 。 原 来 不 懂 编 程 的 人 ， 多 参考 JavaScript 示例 代码 ， 也 能 很 快 上 手 。 

JavaScript 主要 是 基于 客户 端 运行 的 ， 用 户 单 击 带 有 JavaScript 的 网 页 ， 网 页 里 的 
JavaScript 就 传 到 浏览 器 ， 由 浏览 器 处 理 。 前 面 提 到 的 下 拉 菜 单 、 验 证 表单 有 效 性 等 大 量 
互动 性 功能 ， 都 是 在 客户 端 完成 的 ， 不 需要 和 Web Server 进行 任何 数据 交换 ， 因 此 ， 不 会 
增加 Web Server 的 负担 。 

几乎 所 有 浏览 器 都 支持 JavaScript, 如 Internet Explorer (IE)、Firefox、 Netscape、 Mozilla 
和 Opera 等 。 


3，CSS 概述 


CSS 样式 表 定 义 如 何 显示 HTML 元 素 ， 就 像 HTML 的 字体 标签 和 颜色 属性 起 的 作用 
那样 。 样 式 通常 保存 在 外 部 的 .CSS 文件 中 。 仅 编辑 一 个 简单 的 CSS 文档 ， 外 部 样式 表 就 
可 同时 改变 站 点 中 所 有 页 面 的 布局 和 外 观 。 


由 于 允许 同时 控制 多 重 页 面 的 样式 和 布局 ，CSS 可 以 称 得 上 Web 设计 领域 的 一 个 突 | 


破 。 作 为 网 站 开发 者 ， 能 够 为 每 个 HTML 元 素 定义 样式 ， 并 将 其 应 用 于 所 希望 的 任意 多 个 
页 面 中 。 如 需 进 行 全 局 变换 ， 只 需 简单 地 改变 样式 ， 网 站 中 的 所 有 元 素 均 会 自动 地 更 新 。 


8.7.4_B/S 系统 结构 


B/S (BrowserServer) 结构 即 浏览 器 和 服务 器 结构 。 它 是 随 着 Intemet 技术 的 兴起 ， 

对 C/S 结构 的 一 种 变化 或 者 改进 的 结构 。 在 B/S 结构 下 , 用 户 工作 界面 是 通过 WWW 浏览 
器 来 实现 的 ， 极 少 部 分 事务 逻辑 在 前 端 (Browser) 实现 ， 但 是 主要 事务 逻辑 在 服务 器 端 
(Server) 实现 ， 形 成 所 谓 三 层 (3-tier) 结构 。 这 样 就 大 大 简化 了 客户 端 计算 机 载荷 ， 减 
轻 了 系统 维护 与 升级 的 成 本 和 工作 量 ， 降 低 了 用 户 的 总 体 成 本 (CTCO)。 以 目前 的 技术 看 ， 
局 域 网 建立 B/S 结构 的 网 络 应 用 ， 并 通过 Intermet/Intranet 模式 下 数据 库 应 用 ， 相 对 易于 把 
握 ， 成 本 也 是 较 低 的 。 它 是 一 次 性 到 位 的 开发 ， 能 实现 不 同 的 人 员 从 不 同 的 地 点 以 不 同 的 
接 入 方式 (如 LAN、WAN、Internet/Intranet 等 ) 访问 和 操作 共同 的 数据 库 ， 它 能 有 效 地 保 
护 数据 平台 和 管理 访问 权限 , 服务 器 数据 库 也 很 安全 。 特别 是 在 Java 这 样 的 跨 平台 语言 出 
现 之 后 ，B/S 结构 管理 软件 更 是 方便 、 速 度 快 、 效 果 好 。 其 系统 结构 如 图 8.2 所 示 。 
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图 8.2 B/S 系统 结构 
随 着 Intemet 和 WWW 的 流行 ， 以 往 的 主机 /终端 和 C/S 都 无 法 满足 当前 的 全 球 网 络 开 
、 互 联 、 信 息 随处 可 见 和 信息 共享 的 新 要 求 ， 于 是 就 出 现 了 B/S 型 模式 。B/S 结构 最 大 的 
点 是 用 户 可 以 通过 WWW 浏览 器 访问 Intemet 上 的 文本 、 数 据 、 图 像 、 动 画 、 视 频 点 播 和 


声音 信息 ， 这 些 信 息 都 是 由 许 许多 多 的 Web 服务 器 产生 的 ， 而 每 一 个 Web 服务 器 又 可 以 通 


各 种 方式 与 数据 库 服务 器 连接 ， 大 量 的 数据 实际 存放 在 数据 库 服务 器 中 。 客 户 端 除了 


| WWW 浏览 器 ， 一 般 无 需 任何 用 户 程序 ， 只 需 从 Web 服务 器 上 下 载 程序 到 本 地 来 执行 ， 在 


载 过 程 中 若 遇 到 与 数据 库 有 关 的 指令 ， 由 Web 服务 器 交 给 数据 库 服 务 器 来 解释 执行 ， 并 
回 给 Web 服务 器 ，Web 服务 器 又 返回 给 用 户 。 在 这 种 结构 中 ， 将 许 许多 多 的 网 连接 到 一 
， 形 成 一 个 巨大 的 网 ， 即 全 球 网 。 而 各 个 企业 可 以 在 此 结构 的 基础 上 建立 自己 的 Intranet。 
1. B/S 结构 的 优点 

B/S 结构 的 优点 如 下 : 

回 ”具有 分 布 性 特点 ， 可 以 随时 随地 进行 查询 、 浏 览 等 业务 处 理 。 

回 业务 扩展 简单 方便 ， 通 过 增加 网 页 即 可 增加 服务 器 功能 。 
回 ”维护 简单 方便 ， 只 需要 改变 网 页 ， 即 可 实现 所 有 用 户 的 同步 更 新 。 
回 

2 


开发 简单 ， 共 享 性 强 。 
，B/S 结构 的 缺点 


B/S 结构 的 缺点 如 下 : 

回 个 性 化 特点 明显 降低 ， 无 法 实现 具有 个 性 化 的 功能 要 求 〈 个 性 化 的 要 求 取决 于 软 
件 框 架 ， 而 非 架 构 ， 分 享 B/S 软件 就 很 灵活 ) 。 

回 ”以 鼠标 为 最 基本 的 操作 方式 ， 无 法 满足 快速 操作 的 要 求 〈 如 果 辅 助 于 插件 ， 可 以 
用 键盘 快速 操作 ) 。 

回 页面 动态 刷新 ， 响 应 速度 明显 降低 〈 分 享 软件 用 分 页 保证 响应 速度 稳定 ) 。 

回 ”功能 弱化 ， 难 以 实现 传统 模式 下 的 特殊 功能 要 求 。 


8.8 需求 分 析 


计算 机 信息 发 展 的 步伐 在 很 大 程度 上 推动 了 商业 的 电子 化 与 网 络 化 ， 电 子 商 务必 将 成 
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为 21 世纪 的 网 络 发 展 主流 。 时 下 ， 网 上 购物 将 成 为 一 种 购物 时 尚 。 目 前 国内 企业 正 纷纷 
加 入 到 阿里 巴巴 等 一 系列 大 型 电子 商务 网 站 中 。 


8.8.1 必要 性 与 可 行 性 分 析 


随 着 Internet 的 发 展 ， 电 子 商 务 已 逐渐 被 大 多 数 企业 接受 并 认可 。 很 多 企业 在 看 到 网 | 


络 B2B (企业 对 企业 ) 网 上 交易 的 成 功 案例 之 后 ， 充 分 认识 到 网 络 交易 将 成 为 未 来 商品 交 
易 的 重要 组 成 部 分 。 所 以 ， 各 个 企业 在 建立 企业 宣传 网 络 的 同时 ， 也 逐步 扩大 企业 自身 的 
网 络 销售 渠道 ， 建 立 起 自己 的 电子 商务 网 站 ， 完 成 了 从 B2B 到 B2C (企业 对 个 人 ) 同时 
进行 网 络 交易 的 过 渡 ， 大 大 提高 了 企业 生产 效益 。 随 着 硬件 技术 、 网 络 技术 及 网 上 交易 法 
规 的 日 趋 完善 ， 电 子 商 务 将 成 为 企业 销售 经 营 的 主要 渠道 。 

目前 ， 可 以 开发 动态 网 站 的 主流 语言 有 PHP、JSP 和 NET。 这 3 种 主流 Web 开发 技术 
各 有 千秋 ， 其 中 ，PHP 网 络 编程 技术 因 其 安全 、 稳 定 、 易 开发 等 卓越 特性 广 受 人 们 好 评 ， 
并 在 整个 Web 开发 领域 应 用 广泛 ， 另 外 ， 利 用 PHP 所 开发 的 Web 程序 支持 多 种 操作 系统 
平台 且 有 较 好 的 程序 移植 性 。 

本 电子 商务 网 站 系统 利用 当前 网 站 流行 的 构架 方式 (ApachetMySQL+PHP)， 并 应 用 
Windows 作为 搭载 平台 建立 整个 系统 的 Web 服务 器 。 由 于 Apache、MySQL 与 PHP 具有 良好 
的 开源 性 与 免费 性 ， 可 以 为 企业 在 开发 电子 商务 网 站 过 程 中 极 大 地 降低 成 本 并 缩短 开发 周期 。 


8.8.2 ”系统 需求 


根据 对 电子 商务 网 站 系统 的 分 析 , 可 以 将 整个 系统 分 为 购物 车 、 用 户 中心 、 热 门 商品 、 
商品 评价 等 6 个 部 分 。 电 子 商 务 网 站 的 整体 结构 和 各 功能 模块 如 图 8.3 所 示 。 


, 
册 人行 理 
关 
价 | “| 名 


图 8.3 系统 总 体 功 能 图 
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|” 
8.8.3 ”功能 需求 


| 的 考察 、 分 析 ， 并 结合 企业 电子 商务 网 站 的 未 来 发 展 需要 ， 要 求 本 系统 具有 以 下 功能 : 


所 谓 电 子 商 务 系统 ， 其 实质 就 是 一 个 虚拟 的 购物 超市 系统 。 通 过 对 电子 商务 网 站 实际 


| 回 ”网 站 设计 页 面 要求 美 观 大 方 、 个 性 化 ， 功 能 全 面 ， 操 作 简 单 。 
oo 回 ”实现 用 户 登 录 、 注 册 、 找 回 密码 等 用 户 操作 功能 。 
加 ”实现 迅速 查找 商品 功能 。 
”加 ”实现 轻松 、 方 便 购物 体验 。 
加 ”实现 商品 分 类 详尽 ， 可 按 不 同类 别 查 看 商品 信息 。 
加 ”提供 快速 商品 检索 功能 ， 保 证 数据 查询 的 灵活 性 。 
”加 实现 商品 查看 、 购 买 商 品 功能 。 
回 ”实现 综合 条 件 查询 ， 如 按 用 户 指定 条 件 查 询 、 按 关键 字 查 询 、 按 会 员 价 格 等 条 件 查询 。 
加 ”实现 用 户 权限 优惠 等 级 。 
加 ”实现 订单 查询 功能 。 
回 “提供 灵活 、 方 便 的 权限 设置 功能 ， 使 整个 系统 的 管理 分 工 明确 。 
回 ”具有 易 维护 性 和 易 操 作 性 。 
8.8.4 系统 性 能 要 求 


该 系统 设计 目标 是 开发 一 个 适合 中 小 型 企业 使 用 的 网 上 购物 系统 。 用 户 可 以 在 网 上 迅 
速 地 查找 到 自己 喜欢 的 商品 ， 从 而 使 购物 变 得 轻松 、 方 便 。 用 户 在 该 系统 购买 商品 之 后 ， 
只 需 等 待 送 货 上 门 。 对 经 营 者 来 说 可 以 很 好 地 配置 人 力 ， 通 过 网 络 提高 企业 的 知名 度 。 随 
着 计算 机 网 络 的 高 速 发 展 ， 网 上 购物 将 成 为 以 后 的 发 展 趋势 ， 网 上 消费 将 成 为 一 种 消费 时 
尚 。 一 个 优秀 的 网 上 购物 系统 应 该 具备 以 下 性 能 : 
商品 信息 的 合理 管理 。 
方便 易 懂 的 网 上 购物 方法 。 
商家 与 用 户 的 交流 性 。 
合理 的 用 户 管理 。 
安全 的 订单 管理 机 制 。 


8.9 系统 数据 库 设 计 


办 办 凶 


目前 ， 成熟 而 且 广 泛 占 领 市 场 的 数据 库 产品 一 般 都 是 关系 型 数据 库 产品 。 关 系 型 数据 
库 产品 具有 坚实 的 理论 基础 ， 基 于 关系 演算 和 关系 模型 ， 并 且 提供 非 面向 过 程 的 查询 语言 
SQL， 因 此 深 受 市 场 的 欢迎 。 作 为 PHP 的 黄金 搭档 ，MySQL 数据 库 不 仅 存储 和 管理 功能 
强大 ， 而 且 是 完全 免费 的 ， 可 以 从 很 多 网 站 下 载 ， 这 样 可 以 为 企业 节省 很 大 一 部 分 开支 。 
PHP 中 也 提供 了 强大 的 支持 MySQL 数据 库 的 函数 ，phpMyAdmin 为 MySQL 数据 库 提 供 
了 图 形 化 界面 ， 所 以 本 系统 采用 MySQL 作为 数据 库 。 
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8.9.1 数据 库 理论 基础 


一 个 成 功 的 信息 管理 系统 ， 是 建立 在 许多 条 件 之 上 的 ， 而 数据 库 是 其 中 一 个 非常 重要 | 


的 条 件 和 关键 技术 。 


信息 管理 系统 所 涉及 的 数据 库 设计 分 5 个 步骤 : 数据 库 需 求 分 析 、 概 念 设计 、 邮 辑 设 | 


计 、 物 理 设计 与 加 载 测试 。 

数据 库 需 求 分 析 的 任务 是 将 业务 管理 单 证 流 化 为 数据 流 ， 划 分 主题 之 间 的 边界 ， 绘 制 
出 DFD 图 ， 并 完成 相应 的 数据 字典 ， 概 念 设计 的 任务 是 从 DFD 出 发 ， 绘 制 出 本 主题 的 实 
体 一 关系 (E-R) 图 ， 并 列 出 各 个 实体 与 关系 的 纲要 表 ; 逻辑 设计 的 任务 是 从 E-R 图 与 对 


应 的 纲要 表 出 发 ， 确 定 各 个 实体 及 关系 的 表 名 属性 ;物理 设计 的 任务 是 确定 所 有 属性 的 类 | 


型 、 宽 度 与 取 值 范围 ， 设 计 出 基本 表 的 主键 ， 将 所 有 的 表 名 与 字段 名 英文 化 〈 现 在 很 多 软 | 


件 能 支持 中 文字 段 ， 如 MS SQL Server)， 实 现 物 理 建 库 ， 完 成 数据 库 物理 设计 字典 ， 加 载 
测试 工作 贯穿 于 程序 测试 工作 的 全 过 程 ， 整 个 输入 、 修 改 、 查 询 和 处 理工 作 均 可 视 为 对 数 
据 库 的 加 载 测试 工作 。 

要 设计 出 一 个 好 的 信息 管理 系统 数据 库 ， 除 满足 系统 所 要 求 的 功能 外 ， 还 必须 遵守 下 
列 原则 : 

回 ”基本 表 的 个 数 越 少 越 好 。 

回 “主键 的 个 数 越 少 越 好 。 键 是 表 间 连接 的 工具 ， 主 键 越 少 ， 表 间 的 连接 就 越 简单 。 

回 “字段 的 个 数 越 少 越 好 。 

回 ”所 有 基本 表 的 设计 均 应 尽量 符合 第 三 范式 。 

数据 库 的 设计 中 ， 如 何 处 理 多 对 多 的 关系 和 如 何 设计 主键 ， 是 两 个 有 着 较 大 难度 、 需 
要 重点 考虑 的 问题 。 下 面 着 重 从 SQL 应 用 、 数 据 库 设 计 范 式 和 查询 优化 等 方面 来 分 析 本 
课题 的 系统 关键 技术 和 实现 难点 ， 并 加 以 解决 。 


8.9.2 ”系统 实体 E-R 图 


由 于 实体 之 问 存在 相互 关系 ， 所 以 用 E-R 图 来 表示 实体 之 间 的 关系 。 考 虑 到 篇 幅 ， 所 
有 实体 或 关系 的 详细 字段 和 关键 字 并 未 给 出 ， 但 在 后 面 将 详细 列 出 数据 库 的 内 容 和 详细 说 
明 。 数 据 库 E-R 图 如 图 8.4 所 示 。 


图 8.4 数据 库 E-R 图 
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| 8.9.3 ”系统 数据 表 设 计 


结合 实际 情况 及 对 用 户 需求 的 分 析 ， 电 子 商 务 系统 shop 数据 库 主 要 包含 admin (管理 
员 表 )、user (用 户 信息 表 )、dingdan (用 户 订单 表 )、leaveword (用户 留言 表 )、pingjia( 商 
品评 价 表 )、shangpin (商品 信 息 表 )、gonggao (系统 公告 表 )、type〔 商 品 大 类 表 )、ip ( 访 


客人 记录 表 ) 等 数据 表 。 
电子 商务 系统 数据 库 中 主要 数据 表 的 设计 结构 如 表 8.1~ 表 8.9 所 示 。 


食 四 


表 8.1 admin 表 


管理 员 密码 


数据 类 型 字段 大 小 说 了 明 

id int 4 主键 自动 编号 ID 
name varchar | 50 | | 用 户 名 
pwd varchar | 50 | | 用 户 密码 
dongjie int | “4 | | 标记 用 户 是 否 被 冻结 
email varchar 

sfzh varchar 

tel varchar 

qq varchar 

ip varchar 

tishi varchar 

huida varchar 

dizhi varchar 

oubian Varchar 

regtime datetime 

truename varchar 

pwdl varchar 
字段 名 称 数据 类 型 

id int 

dingdanhao Varchar 

spe varchar 

slc varchar 

shouhuoren varchar 

SeX Varchar 

dizhi Varchar 

youbian Varchar 

tel Varchar 


2s 


字段 名 称 


email | varchar E-mail 

sh 位 | varchar 收 货 方式 
Zfff | varchar 支付 方式 
leaveword | text 用 户 留言 
time | datetime 下 单 时 间 
xiadanren | varchar 下 单 人 姓名 
zt | 订单 状态 


total 


字段 名 称 数据 类 型 
id int 自动 编号 ID 
userid int 用 户 ID 
title Varchar 留言 主题 
time datetime 留言 时 间 


Content 


text 


字段 名 称 数据 类 型 
id int 
userid int 
title varchar 
time datetime 
spid int 
content text 

表 8.6 shangpin 表 

字段 名 称 数据 类 型 是 否 主键 说 阴 
id int | 4 | 主键 自动 编号 ID 
mingcheng varchar 商品 名 称 
jianjie text | 商品 价格 
addtime datetime 入 市 时 间 
dengii Varchar 50 商品 等 级 
Xinghao Varchar 50 商品 型 号 
tupian Varchar 200 图 片 路 径 
shuliang int 4 商品 数量 
cishu int 4 购买 次 数 
tuijian int 4 是 否 推荐 
ypeid int 4 类 型 ID 
huiyuanjia float | ss | 会 员 价 
shichangjia float 上 一 “六 二 一 = 市 场 价 
Pinpai varchar 50 一 一 一 品牌 
tejia int 2 是 否 特 价 


明 
自动 编号 ID 
访客 IP 


8.10 系统 设计 


18. 10.1 系统 实现 结构 图 
电子 商务 系统 的 前 、 后 台 结 构 分 别 如 图 8.5 和 图 8.6 所 示 。 


电子 商务 系 妨 首页 


Lai A 

~ 
是 新 商品 展示 | 推荐 商品 展示 | 热门 商品 展示 | 商品 分 类 展 | 用 户 注册 | 
Shorner php A shewtaijian phy A | shorhot php A hor , 


内 


~ 也 六 吹 | 六 哗 


修改 密码 | | 
er | wg LN a 
te ss 

~ 除了 下界 ph 


RN 


图 8.5 前 台 文件 结构 图 


注意: 
为 了 使 读者 对 系统 文件 有 一 个 更 清晰 的 认识 , 笔者 从 B/S 角度 出 发 , 设计 了 构思 合理 
功能 齐全 的 电子 商务 系统 文件 架构。 
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注 往 订单 
lookdd phe 


让 
本 
人 有 
二 人 2 
| 修改 商 品 信息 ee 
et CL | Pe b Ws, 


图 8.6 后 台 文件 结构 图 


8.10.2 ”系统 功能 模块 设计 


1. 系统 的 功能 模块 


从 电子 商务 网 站 的 基本 功能 角度 考虑 ， 整 个 电子 商务 网 站 系统 主要 由 前 台 系统 和 后 台 
系统 共同 组 成 ， 前 台 系 统 主要 由 分 类 商品 展示 、 用 户 登录 、 查 询 和 购物 车 等 模块 构成 。 其 
中 ， 分 类 商品 展示 模块 包括 最 新 商品 展示 、 推 荐 商品 展示 、 热 门 商品 展示 以 及 商品 分 类 展 
示 等 功能 ， 登 录 模块 主要 用 于 实现 用 户 的 账号 注册 、 账 号 登录 等 操作 ;查询 模块 主要 用 于 
实现 商品 的 查询 以 及 用 户 订 单 号 的 查询 操作 ; 购物 车 模块 主要 用 于 登录 用 户 订购 电子 商务 
网 站 中 所 陈列 的 商品 。 后 台 系 统 由 公告 管理 、 订单 管理 、 商 品 管理 和 用 户 管理 等 模块 构成 ， 
其 中 ， 公 告 管理 模块 包括 更 改 公告 信息 和 添加 公告 信息 操作 ; 订单 管理 模块 包括 编辑 订单 
和 查询 订单 操作 ， 商 品 管理 模块 包括 添加 、 修 改 商品 信息 和 添加 、 管 理 商 品类 别 操作 ;用 
户 管理 模块 包括 用 户 信息 管理 、 更 改 管理 员 信息 等 操作 。 


2.， 系统 功能 模块 特点 


电子 商务 网 站 系统 可 以 根据 不 同 的 模块 实现 基本 的 网 上 商城 功能 ， 该 前 台 系 统 可 以 帮 
助 用 户 快速 、 方 便 地 浏览 网 站 中 的 商品 ， 并 提供 完善 的 订购 体系 。 男 外 ， 用 户 可 以 通过 查 
询 模块 筛选 商品 信息 ， 以 查找 特定 条 件 商品 。 

后 台 管 理 系统 为 网 站 管理 人 员 提 供 安全 、 稳 定 、 高 效 的 管理 体制 。 整 个 后 台 管 理 系统 
具有 层次 分 明 、 方 便 管理 、 易 于 维护 等 功能 特点 。 前 台 系统 与 后 台 系 统 共同 组 成 了 一 个 健 
全 的 网 上 购物 及 管理 系统 。 


"00s 


Te 人 Bi 项 目 业 例 分 析 
8.11 系统 功能 实现 


8.11.1 商品 展示 模块 设计 


商品 展示 模块 主要 包括 推荐 商品 展示 、 最 新 商品 展示 、 热 门 商品 展示 、 商 品 分 类 展示 
和 查看 商品 信息 5 个 功能 。 

1.， 推荐 商品 展示 

单 击 电子 商务 网 站 首页 的 “推荐 商品 ” 超 链 接 ， 即 可 进入 推荐 商品 显示 页 面 。 显 示 推 
荐 商品 的 实现 方法 与 用 户 账号 冻结 /解冻 的 方法 类 似 , 即 在 后 台数 据 库 设置 一 个 代表 推荐 的 
| 字段 名 称 ， 在 添加 每 个 商品 时 ， 如 果 该 商品 为 推荐 商品 ， 则 更 改 该 商品 的 推荐 商品 字段 即 
可 实现 。 推 荐 商品 展示 页 面 如 图 8.7 所 示 。 
| 说 明 ; 
| 添加 商品 时 ， 如 果菜 件 商品 为 重点 推荐 商品 ， 则 使 tuijian 的 值 为 1。 显示 重点 推荐 商 
” 品 就 是 将 tuijian 的 值 为 1 的 商品 显示 出 来 。 


的 一 第 关 识 串 一 一 
商品 名 称 : 。 单反 数码 相机 
商品 品 1 晶 : 。 FTPA 商品 型 号 : WK-1000 
商品 简介 :FIFA 单反 相机 
上 市 日 期 : 。 2011-2-1 再 余数 量 : 50 商品 等 级 : 一 般 
商场 价 : 7500 元 会 员 价 ; 7200 元 新 扣 : 96% 
YE 


商品 名 称 : 。 FSF-3000 

商品 品 钼 : SONY 商品 型 号 : 3005 

商品 简介 : 。 常 尼 公 司 于 2008 年 10 月 发 布 的 芋 三 代 PlsyStsti on 便捷 式 手 季 戎 戏 机 
上 市 日 期 :2010-1-! 惠 余 数量 : 5 商品 等 组: 精品 
商场 价 : 。 1250 元 会 员 价 ; 1200 元 折扣 :sex 


上 市 日 期 ; 。 2010-1-1 制作 数量 : 苇 商品 等 级 : 精品 
商场 价 : 399 元 会 员 价 : 269 元 新 扣 : 713% 
EE 


本 站 共有 推荐 产品 3 件 插页 显示 20 件 第 ! 页 / 共 ! 页 1 


8.7 推荐 商品 展示 页 面 


昌 
时 
到 
国 
中 
9 
E 
3 


2， 最 新 商品 展示 

在 电子 商务 网 站 首页 单 击 导航 栏 中 的 “最 新 商品 ” 超 链 接 , 可 进入 最 新 商品 展示 页 面 。 
在 该 页 面 中 ， 将 显示 系统 管理 员 最 新 添加 的 10 件 商品 ， 用 户 可 以 查看 商品 名 称 、 商 品 品 
| 牌 、 商 品 简介 、 上 市 日 期 、 商 场 价 以 及 会 员 价 等 信息 。 已 经 登录 的 用 户 可 以 单 击 “ 放 入 购 
物 车 ”图 标 将 该 商品 放 入 系统 购物 车 中 ， 来 实现 购物 体验 。 最 新 商品 展示 页 面 的 运行 结果 
如 图 8.8 所 示 。 
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商品 呈 绰 : SONY 商品 型 号 : 3006 6 有 
商品 简介 : 。 素 尼 公司 于 2008 年 10 月 发 布 的 第 三 代 PlayStstion 便 拱 式 手 季 游戏 机 。 & 
上 市 日 其 : 2010-1-1 币 余 数量 : 255 商品 等 级 : 种 品 


商场 价 : 。 1250 元 会 员 价 : 1200 元 折扣 :sex 


说 明 : 

最 新 商品 展示 实现 的 原理 是 在 后 台数 据 库 shangpin 表 中 开辟 一 个 addtime 字段 ， 利 用 
该 字段 记录 商品 的 添加 时 间 ， 在 前 台 显示 商品 时 ， 只 需 利用 该 字段 将 所 有 商品 降序 排列 ， 
再 从 排 好 序 的 记录 中 选择 最 后 添加 的 10 条 记录 即 可 。 另 外 ， 热 门 商品 、 商 品 分 类 也 是 通 
过 类 似 的 方法 来 实现 第 选 功能 的 。 


3， 热 门 商 品 展示 | 


在 电子 商务 网 站 首页 单 击 导航 栏 中 的 “热门 商品 ” 超 链接 , 可 进入 热门 商品 展示 页 面 。 
该 页 面 中 显示 的 是 商品 名 称 、 价 格 等 商品 信息 ， 已 经 登录 的 用 户 可 以 单 击 “ 放 入 购物 车 ” 
图 标 将 该 商品 放 入 系统 购物 车 中 ， 以 此 来 实现 购物 体验 。 热 门 商品 展示 页 面 的 运行 结果 如 
图 8.9 所 示 。 


4， 商品 分 类 展示 
在 电子 商务 网 站 首页 单 击 导航 栏 中 的 “分 类 商品 ” 超 链接 ,可 进入 分 类 商品 展示 页 面 。 | 
在 该 页 面 中 ， 可 以 通过 单 击 不 同类 别 的 超 链接 来 筛选 不 同 的 商品 信息 ， 同 样 ， 该 页 显示 的 | 
是 管理 员 最 新 添加 的 10 条 商品 信息 ， 向 用 户 展示 商品 名 称 、 价 格 等 商品 信息 ， 已 经 登录 | 
的 用 户 可 以 单 击 “ 放 入 购物 车 ”图 标 将 该 商品 放 入 系统 购物 车 中 ， 以 此 来 实现 购物 体验 。 | 
商品 分 类 展示 页 面 的 运行 结果 如 图 8.10 所 示 。 


。357 。 
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办 公 类 家 具 类 数码 类 电子 类 书籍 类 
本 类 商品 ?> 办 公关 


商品 名 称 : ”笔记 本 电脑 
商品 局 牌 : 。 草 困 商品 型 号 : 20121542 
| 计 商品 简介 : 无 
| 要 二 em oo 币 全 数量 10 商品 等 级: 一 般 
| 商场 价 : 。 5 元 会 员 价 : 4 元 折扣 : sox 


本 站 共有 该 类 商品 2 件 每 页 显示 10 件 第 1 页 / 共 1 页 1 


| 图 8.10 商品 分 类 展示 页 面 

5. 查看 商品 详细 信息 

为 了 让 用 户 全 面 地 了 解 某 件 商 品 ， 本 购物 系统 设置 了 查看 商品 详细 信息 模块 。 选 择 任 
| 意 类 别 的 商品 并 单 击 “ 查 看 详情 ” 超 链 接 ， 可 进入 显示 该 商品 详细 信息 的 页 面 。 在 该 页 面 
| 中 ， 用 户 不 仅 可 以 通过 商品 信息 对 该 商品 有 整体 了 解 ， 而 且 还 可 以 发 表 个 人 评论 ， 根 据 用 
| 户 的 评论 ， 管 理 人 员 可 以 通过 管理 模块 对 商品 做 部 分 调整 。 查 看 商品 详细 信息 页 面 的 运行 


结果 如 图 8.11 所 示 。 
入 市 时 间 : Pol0-1-1 
市 场 价 : 2so 
BN: om 
区 再 晤 习 


尼 公司 于 2008 年 10 月 发 布 的 第 三 代 PlayStation 便 措 式 手 学 游戏 机 。 


放 入 购物 车 


评论 主题 : [ESP-3000 


让 从 际 了 PSF 60 之 外 就 是 FSF3000 量 好 了 。 个 人 感 区 35580 机 村 屏 庆 比 | 
| 曾 两 代 居 秀 ， 而 换 作 上 又 继承 了 前 两 代 的 优点 。 但 是 体积 咯 大 而 已 。 


评论 内 容 : 


|] ¥en 


| 图 8.11 查看 商品 详细 信息 页 面 
| 
8.11.2 购物 车 模块 设计 


| 购物 车 的 作用 是 用 来 临时 存储 用 户 的 购物 信息 。 用户 可 以 查看 并 对 已 放 入 购物 车 中 的 
| 的 商品 执行 多 种 操作 。 

| 购物 车 模块 主要 包括 添加 商品 至 购物 车 、 查 看 购物 车 、 删 除 购 物 车 内 指定 商品 、 修 改 
商品 数量 、 清 空 购物 车 以 及 结账 6 个 功能 。 
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二 
1.， 添加 商品 至 购物 车 


当 用 户 不 能 决定 是 否 购买 某 种 商品 时 ， 可 以 单 击 该 商品 信息 中 “ 放 入 购物 车 ”图 标 将 | 
该 商品 放 入 购物 车 中 。 添 加 商品 至 购物 车 页 面 的 运行 结果 如 图 8.12 所 示 。 | 


SHOPPING MALL | 


电 弛 商务 康 弦 证 本 时 于 会 合 瑟 电 一 


最 新 商品 “推荐 商品 “热门 商品 ”商品 分 类 用 户 注册 


EP 折扣 小 计 操作 | 
欢迎 % 恪 11 TSP-3000 tt | 120 元 | wx | lo 元 | 大 除 | 
明日 电子 商务 系统 光电 好 标 | 3 元 | 2 元 | | 2 元 | 确 除 
到 | 去 收 维 台 请 空 册 和 车 总计: 1489 


图 8.12 添加 商品 至 购物 车 


2. 查看 购物 车 


用 户 选 购 完 商 品 后 ， 可 以 通过 查看 购物 车 功能 来 查看 当前 购物 车 中 的 商品 信息 。 查 看 | 
购物 车 页 面 如 图 8.13 所 示 。 | 


商品 名 称 数量 市 场 价 会 员 价 折扣 小 计 


失 作 | 

PSF-3000 1 1250 元 1200 元 6Y 1200 元 移 除 | 
光电 必 标 3 | wz | 人 | 2 | Bm | 

区 2 去 收 恨 台 请 本 购物 车 。。 总 计 ; 1459 | 


图 8.13 查看 购物 车 页 面 

3， 操作 购物 车 

操作 购物 车 主要 分 为 删除 指定 商品 、 更 改 商 品 数量 和 清空 购物 车 等 操作 。 用 户 进入 购 
物 车 页 面 ， 在 显示 已 购买 商品 的 信息 表格 中 ， 可 以 看 到 已 经 放 入 购物 车 的 商品 的 信息 。 在 
相应 商品 的 “数量 ”文本 框 中 输入 数量 ， 然 后 单 击 “ 更 改 商 品 数量 ”按钮 ， 可 实现 对 商品 | 
数量 的 更 改 ; 单 击 购物 车 商品 表格 中 “操作 ” 栏 的 “ 移 除 ” 超 链接 ， 即 可 执行 删除 指定 商 | 
品 的 操作 ; 如 果 当 前 登录 用 户 单 击 “ 清 空 购物 车 ” 超 链接 ， 即 可 清空 购物 车 内 的 所 有 商品 。 
其 运行 结果 如 图 8.14 所 示 。 


商品 名 称 


PsP-3000 1250 元 


光志 腿 标 3 
区 二 


8.11.3 ”搜索 模块 设计 


购物 系统 的 商品 种 类 繁多 ， 如 何 使 用 户 方便 、 快 速 地 查找 到 自己 想 要 的 商品 ? 这 就 需 | 
。359 。 ~ 


er 人 ie 项 目 业 例 分 析 
过 RS 


”要 有 专门 的 商品 搜索 模块 。 为 了 满足 不 同 客户 的 需要 ， 整 个 电子 商务 系统 为 用 户 提供 了 简 
| 单 搜索 和 高 级 搜索 两 种 搜索 方式 。 


1. 简单 搜索 


简单 搜索 设置 在 网 站 导航 下 方 ， 设 置 简单 搜索 的 主要 目的 是 方便 用 户 即 时 搜索 查找 ， 
oo 以 此 来 簿 选 特定 的 商品 信息 。 用 户 只 需 在 产品 名 称 文本 框 中 输入 想 要 了 解 商品 信息 的 关键 

字 ， 单 击 “立即 查找 ”按钮 即 可 在 显示 页 中 显示 与 关键 字 匹配 的 产品 信息 。 简 单 搜索 运行 
| 结果 如 图 8.15 所 示 。 


| 图 8.15 简单 搜索 

2. 高 级 搜索 

用 户 如 果 想 进一步 得 到 相关 产品 的 信息 ， 则 可 以 通过 高 级 搜索 对 商品 进一步 筛选 。 单 
击 主页 面 中 的 “高 级 查找 ”按钮 即 可 进入 高 级 搜索 页 面 ， 利 用 系统 提供 的 高 级 搜索 功能 可 
以 精确 地 定位 到 某 件 商 品 。 该 模块 功能 的 实现 是 在 findsp.php 中 完成 的 。 其 运行 页 面 如 
图 8.16 所 示 。 


EE 王 机遇 | 记 
RN | 天 于 到 [名 司 元 
EEE EE 

和 


图 8.16 高 级 搜索 
8.11.4 订单 管理 模块 设计 


| 系统 管理 人 员 是 根据 用 户 订单 来 发 放 货物 的 ， 所 以 订单 管理 模块 的 实现 在 整个 系统 中 
| 起 着 非常 重要 的 作用 ， 该 模块 直接 关系 到 商家 的 信誉 和 消费 者 的 权益 。 订 单 管理 模块 主要 
| 包括 查看 订单 、 执 行 订单 、 打 印 订 单 和 查找 订单 等 操作 。 

1， 查看 订单 

管理 员 通 过 后 台 登 录 模 块 进入 后 台 管理 页 面 ， 单 击 “ 订 单 管理 ” 超 链 接 即 可 进入 订单 
| 管理 页 面 。 当 用 户 提交 订单 后 ， 系 统管 理 人 员 就 可 以 通过 “查看 订单 ”来 查看 用 户 已 经 提 
| 交 的 订单 ， 在 该 模块 中 ， 管 理 人 员 可 以 同时 查看 多 个 用 户 的 订单 信息 ， 并 可 以 同时 删除 多 
个 订单 。 查 看 订单 页 面 如 图 8.17 所 示 。 


201104201T44H3 向 全 考 首 未 作 任何 处 理 | 查看 | [执行 | 万 
011041909333036 笛 快 考 间 | 已 各 已 发 千 已 收 贫 “| 查看 | | 执行 | 证 
本 站 共有 订单 ”条 每 页 明示 25 条 第 1 页 / 共 1 页 ! | 出 际 连 居 天 


图 8.17 查看 订单 页 面 
“360 


| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 订单 号 收 全 方 式 订单 状态 操作 
| 
| 
| 
| 
| 
| 
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2. 执行 订单 


执行 订单 是 为 了 改变 某 订 单 的 当前 状态 ， 从 而 使 管理 人 员 能 够 及 时 、 有 效 地 处 理 每 个 
户 的 订单, 并 记录 当前 订单 的 处 理 状态 , 在 查看 订单 页 面 选中 要 操作 的 订单 号 , 单 击 “ 执 | 
行 ”按钮 即 可 进入 订单 操作 页 面 。 执 行 订单 页 面 如 图 8.18 所 示 。 | 全 


;一旦 商 品 确定 发 货 ， 访 商品 数量 格 自 动 从 库存 中 相应 减少 ， 并 且 不 可 更 攻 
市 场 价 Rt E33 


让 址 : 。。 恬 夫 市 东 匠 大 尘 1234 号 
邮编: 30000 

电话; arl2a456m 

电子 邮件 : 。 esphoneste126 eon 
送 贷方 式 : ”二 快 专递 

支付 方式 :网上 支付 

简单 留 言 :本 请 掩 设 有限 砚 的 请 包 好 ， 速 发 次 9 ! 


图 8.18 执行 订单 页 面 | 
3. 打印 订单 


在 查看 订单 页 面 单 击 指定 商品 后 的 “查看 ”按钮 即 可 进入 订单 预览 页 面 ， 在 该 页 面 单 击 
“打印 ”或 “打印 预览 ”按钮 即 可 执行 相应 操作 。 打 印 订单 页 面 的 运行 结果 如 图 8.19 所 示 。 


1200 
B67 
EEEDREZ 


电话: 0431-12345676 
Joewphonest8125 com | 


:te 支付 方式 : 网 上 :支付 
请 修 在 一 周 内 按 你 的 支付 方式 进行 汇款 汇款 时 注 明 作 的 订单 号 汇款 后 请 及 时 通知 我 们 
[ 关 亲 量 D 自卫 时 间 : 2011-04-20 11.44:11 


8.19 打印 订单 页 面 


4. 查找 订单 


系统 管理 员 可 以 通过 单 击 “ 查 询 订单 ” 超 链接 进入 查找 页 面 。 为 了 便于 系统 管理 员 管 | 
理 订单 ， 该 购物 系统 提供 了 订单 查找 模块 ， 系 统管 理 员 在 相应 的 文本 框 中 输入 下 单 人 姓名 | 
和 订单 号 后 ， 单 击 “ 查 找 ” 按 钮 即 可 执行 订单 查找 操作 。 查 找 订单 页 面 如 图 8.20 所 示 。 | 
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CT 


| 下 订单 人 姓名 订单 号 
| EE 
订单 号 下 单 用 户 订货 人 全 桔 总 计 付款 方式 收 其 方式 | 订单 状 帮 
boiosanta0ssese| = Te T200 maice| Ss FE 
pouowonaiis] ~ 地 区 
po 枝 吸 
ii1041909333036| mr 季 易 % 世 局 汇款 特快 专 进 es 
| Foroworsosses| = win | rm [rmance| Ss Fm 
| EEC 


图 8.20 查找 订单 页 面 
| 


| 8.11.5 ”商品 管理 模块 设计 
| 商品 管理 模块 主要 包括 添加 商品 信息 、 修 改 商 品 信息 和 删除 商品 信息 操作 。 
1.， 添加 商品 信息 


| 

| 

| 通过 添加 商品 信息 这 一 模块 ， 系 统管 理 人 员 可 以 将 新 上 市 的 商品 添加 到 购物 系统 中 
该 模块 页 面 如 图 8.21 所 示 。 
LU | 


CEIEEE 
-+ [5 梧 千 上 本 8F 司 日 
傣 格 : 市 场 价 : 505 元 会 员 价 [6 元 
7 | 
aw | 
[7 
[TT EN 
Er | 
贾 品 效 量 ; [本 
CLL Dr 
人 可 
LL 
到 
Ex] ss 


图 8.21 添加 商品 信息 页 面 


修改 商品 信息 页 面 几乎 和 添加 商品 信息 页 面 完 全 一 样 ， 如 果 修改 商品 成 功 ， 则 弹出 如 
| 图 8.22 所 示 的 对 话 框 。 


| 8.22 ”商品 修改 成 功 提示 对 话 框 
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3. 删除 商品 信息 


为 了 管理 方便 ， 本 系统 设计 时 采用 了 能 够 同时 删除 多 件 商品 的 方式 ， 这 主要 考虑 到 系 
统 中 的 商品 可 能 较 多 ， 一 次 淘汰 的 商品 也 可 能 很 多 ， 如 果 一 件 一 件 地 删除 会 浪费 大 量 的 操 ，  / 
作 时 间 ， 采 用 本 系统 的 删除 方式 只 需 选 中 欲 删 除 商 品 前 的 复 选 框 ， 选 择 完毕 后 ， 单 击 “ 删 | 国 - 
除 选择 ” 按 扭 即 可 完成 删除 多 项 商品 的 任务 。 删 除 商品 信息 页 面 如 图 8.23 所 示 。 | 


图 8.23 删除 商品 信息 页 面 


MNote 

ED 名 称 En 型 8 。 | 利 作 | 而 声 价 | 会 员 价 | 买 出 加 入 时 间 控 作 | 
F | Wawa | rr ri | mm |r | rm | o Ee Ea | 
[a Fp-3000 Som 3006 255 1250 1200 0 2010-1-1 E73 | 
F 光志 尼 标 4 lrnawe] wm | 25 | 2 2 2010-1-1 了 | 
F 弟 记 本 电 应 E73 aozse | 0 5 4 0 2010-1-1 EE | 
| 量 有 过 择 | | 重新 选择 | 本 站 共有 货物 《 件 每 页 明示 20 件 第 ! 页 / 共 ! 页 1 | 
| 

| 

| 

| 


说 明 : 
本 章 仅 介绍 电子 商务 网 站 的 部 分 功能 模块 。 其 中 ， 登 录 模 块 、 站 内 短信 模块 和 部 分 管 
理 模 块 没有 列 出 ， 读 者 可 根据 实际 情况 自行 增 减 模块 。 


8.12 结 论 


通过 实际 的 调查 和 应 用 ， 可 以 看 出 本 电子 商务 系统 已 经 基本 满足 了 行业 的 设计 要 求 ， 
通过 Web 技术 实现 了 电子 商务 的 基本 功能 。 但 是 , 在 实际 应 用 调查 中 ,发 现 整个 系统 仍 有 | 
不 足 和 缺陷 ， 需 要 对 程序 进一步 改进 。 但 在 应 用 的 整体 反馈 中 ， 与 预期 希望 差别 不 大 ， 基 | 
本 达到 了 预期 效果 。 | 
本 设计 以 B/S 系统 作为 基本 结构 ， 应 用 PHP 相关 技术 ， 结 合 CSS、JavaScript 等 主流 | 
技术 实现 完整 的 电子 商务 网 站 系统 。 通 过 行业 调查 ， 围 绕 主流 Web 开发 应 用 技术 ,结合 电 | 
子 商 务 本 身 需 求 ， 对 整个 系统 的 大 体 实现 过 程 进行 了 讲解 。 从 系统 的 稳定 性 与 安全 性 角度 | 
考虑 ， 数 据 库 部 分 采用 MySQL， 在 整个 开发 过 程 中 降低 了 成 本 。 | 
在 整个 系统 设计 过 程 中 ， 遇 到 了 以 下 问题 : 
回 “系统 连接 数据 库 时 ， 如 果 函 数 mysql_connect0 中 参数 填写 错误 ， 则 会 导致 系统 无 | 
法 与 后 台数 据 库 连 接 。 
回 PHP 版 本 兼容 性 问题 。 在 低 版 本 中 开发 的 程序 可 能 会 在 PHP 高 版 本 运行 时 输出 警 
告 提示 。 
回 ”编码 格式 问题 。 从 数据 库 中 提取 的 汉字 可 能 显示 成 乱码 。 
加 ”如 果 用 户 留 言 内 容 包 含 空格 、“&”、 回 车 等 特殊 字符 ， 在 前 台 可 能 无 法 显示 或 
显示 错误 。 
总 体 来 说 ， 本 程序 设计 还 是 成 功 的。 不 仅 满足 了 电子 商务 网 站 的 基本 需求 ， 同 时 添加 
了 商品 类 别 选择 功能 ， 使 网 站 整体 结构 更 加 清晰 ， 并 取得 了 预期 测试 结果 。 
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| 对 于 各 个 电子 商务 实际 应 用 情况 ， 该 系统 中 部 分 模块 仍 需要 根据 个 体 因素 进一步 调整 
| 和 改进 。 该 电子 商务 网 站 系统 仍 有 待 于 完善 。 
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8.14 致 谢 
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| 

| 

| 

| 

| 

| 致谢 是 对 指导 教师 和 给 予 指导 或 协助 完成 设计 工作 的 组 织 和 个 人 表示 感谢 。 下 面 给 出 
| 一 个 致谢 示例 。 

| 毕业 设计 是 我 们 在 大 学 阶段 所 做 的 最 后 一 件 事 ， 也 是 很 重要 的 一 件 事 。 它 不 仅 给 我 们 
| 的 大 学 生涯 甚至 学 生生 涯 画 上 了 一 个 完满 的 句号 ， 而 且 也 通过 动手 实践 给 自己 上 了 在 大 学 
| 的 最 后 一 堂 课 ， 通 过 它 所 学 到 的 东西 对 我 们 以 后 的 发 展 有 莫大 的 帮助 。 

| 毕业 设计 并 非 一 帆 风 顺 ， 之 中 也 遇见 过 困难 ， 经 历 过 挫折 ， 我 也 曾 懒惰 过 、 喜 悦 过 、 
苦恼 过 ， 也 曾经 感慨 “ 书 到 用 时 方 恨 少 ”。 毕 业 设 计 的 日 子 会 让 我 久久 难忘。 实习 的 过 程 
| 让 我 对 本 专业 的 知识 有 了 新 的 认识 。 在 以 往 四 年 的 学 习 过 程 中 ， 我 只 片面 地 注重 了 理论 知 
| 识 的 识 记 和 分 析 ， 而 忽略 了 动手 能 力 的 培养 。 这 个 实际 题目 使 我 真正 发 现 只 有 一 些 浅水 的 
| 基础 理论 是 远 远 不 够 的 ， 只 有 理论 和 实践 相 结 合 才 真正 合格 。 

| 在 这 里 ,我 由 囊 地 感谢 半年 来 帮助 过 我 的 各 位 老师 ， 正 是 有 了 他 们 的 热心 帮助 和 耐心 
| 指导 ， 我 才 会 认识 到 自己 的 不 足 ， 在 实践 中 不 断 改正 自己 犯 下 的 错误 ， 使 得 我 的 毕业 设计 
| 得 顺利 完成 。 

我 更 要 感谢 我 的 指导 教师 XX 老师 ， 每 当 我 遇 到 困难 难以 解决 时 ， 他 总 是 给 我 细致 入 
| 微 的 指导 ， 鼓 励 我 耐心 地 思考 遇 到 的 问题 ， 引 导 我 积极 地 寻找 解决 问题 的 方法 ， 从 他 身上 
我 看 到 了 一 个 老师 的 敬业 精神 ， 在 这 里 我 诚 拘 地 感谢 XX 老师 对 我 的 教育 和 培养 。 

| 

| 
| 
] 
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8.15 附 录 


附录 主要 包括 与 设计 《论文 ) 有 关 的 图 表 、 程 序 、 运 行 结果 ， 以 及 主要 设备 、 仪 器 仪 | 
表 的 性 能 指标 和 测试 精度 等 。 


8.15.1 附录 A 主 程序 (Index.php 代码 ) | Note 
0 <php | 
02 include("top.php"): | 
03 ed | 
04 <table width="800" height="438" border="0" align="center" cellpadding="0" cellspacing="0"> | 
05 <tr> | 
06 <td width="200" height="438" valign= "top" bgcolor="#E8ES8ES8"> | 
07 <div align="center"> ! 
08 <2php include("left.php"):?> | 
09 </div></td> | 
10 <td width="10" background="images/line2.8if'>&nbsp:</td> | 
11 <td width="590" valign="top"> | 
12 <table width="590" border="0" align="center" cellpadding="0" cellspacing="0"> | 
13 <tr> | 
14 <td width="15" rowspan="2">&nbsp:</td> | 
15 <td height="25" colspan="2"> | 
16 <divalign="left"><img src="images/yqlj.gif' width="250" height="25"></div> | 
17 <hd> | 
18 </tr> | 
19 <tr> | 
20 <td width="22" height="50">&nbsp:</td> | 
21 <td width="553"><table width="93%" border="0" cellpadding="0" cellspacing= "0"> | 
22 <!--DWLayoutTable--> | 
23 <t> | 
24 <td width="65" rowspan="2" valign="top"> | 
25 <img src="images/] 1.gif" width="65" height="40"></td> | 
26 <td width="75" height="21"> | 
27 <div align="center"> | 


28 <a href="http://www.mingrisoft.com/about.asp">MRSOFT</a><a href="http://www.163.net"> 
</a> </div></td> 


29 <td width="75"> 
30 <divalign="center"><a href="http://www.mingrisoft.cony/about.asp">MRSOFT</a></div></td> 
31 <td width="75"><div align="center"> 


32 <a href="http://www.mingrisoft.com/about.asp">MRSOFT</a> 
33 <a href="http://freemail.yeah.net/"></a> </div></td> 


34 <td width="75"><div align="center"> 
35 <a href="http://www.mingrisoft.com/about.asp">MRSOFT</a></div></td> 
36 <td width="75"><div align="center"> 


37 <a href="http://www.mingrisoft.com/about.asp">MRSOFT</a> 
38 <a href="http://www.microsoft.com/china/"></a></div></td> 
39 <td width="75"><div align="center"> 
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| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
上 


40 <a href="http://www.mingrisoft.com/about.asp">MRSOFT</a><a href="http://www.china. 
com"></a></div></td> 


41 </tr> 
42 <tr> 
43 <td height="18" valign= "top"><div align="center"> 


44 <a href="http://www.mingrisoft.com/about.asp" >MRSOFT</a><a href="http://d.baidu.com"> 
</a> </div></td> 

45 <td valign="top"><div align="center"> 

46 <a href="http://www.mingrisoft.com/about.asp">MRSOFT</a><a href="http://www.tom. 


| com"></a><br> 


47 </div></td> 

48 <td valign="top"><div align="center"> 

49 <a href="http://www.mingrisoft.com/about.asp">MRSOFT</a><a href="http://www.hao123. 
com"></a></div></td> 
| 50 <td valign="top"> 

51 <div align="center"> 


52 <a href="http://www.mingrisoft.com/about.asp">MRSOFT</a><a href="http://cn.yahoo. 
com"></a> </div></td> 

53 <td valign="top"><div align="center"> 

54 <ahref="http://www.mingrisoft.com/about.asp">MRSOFT</a> 

SS <a href="http://download.lycos.com.cn/"></a></div></td> 

56 <td valign="top"> 

5 <div align="center"><a href="http://www.mingrisoft.com/about.asp">MRSOFT</a></div> 


</td> 
58 </t> 
59 </table></td> 
60 </> 
61 <t> 
62 <td height="10" colspan="3" backeround="images/linel .gif'></td> 
63 </t> 
64 </table> 
65 <table width="556" border="0" align="center" cellpadding="0" cellspacing=' 
66 <tr> 
67 <td height="25"><img src="images/tjsp.gif" width="500" height="25"></td> 
68 </tr> 
69 </table> 
70 <table width="590" border="00" align="center" cellpadding="0" cellspacing="0"> 
il <t> 
了 <td height="110"> 
73 <table width="530" height="110" border="0" align="center" cellpadding="0" cellspacing="0"> 
74 <tr> 
75 <td width="265"> 
76 <?php 
| 2 Ssql=mysql_query("select * from shangpin where tuijian=1 order by 
addtime desc limit 0,1"); 
78 Sinfo=mysql fetch_array($sqD); /返回 查询 信息 
79 if(Sinfo—false) // 判 断 是 否 有 返回 信息 
80 可 
81 echo "本 站 暂 无 推荐 产品 !"; 
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82 

83 

84 

85 

86 

87 

88 

89 

90 

SY 

92 

53 

94 

95 

96 

Cah 
"100" border="0"> 

98 

99 

100 

101 

102 

103 
[mingcheng];?>】 </font></td> 

104 

105 

106 

107 
[shichangjia];?>】 </font></td> 

108 

109 

110 

111 
[huiyuanjia];?>】 </font></td> 

112 

113 

114 

115 
息 </a>】</td> 

116 

117 

118 

119 
入 购物 车 </a>】</td> 

120 

121 

122 

123 

124 
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?> 
<table width="255" border="0" 
<tr> 
<td width="130" rowspan="6"><div align="center"> 
<?php 
if(trim(Sinfo[tupian]—"")) // 判 断 是 否 存在 图 片 
{ 
echo " 暂 无 图 片 "; 


cellspacing="0" cellpadding= 


?> 


"20" height="16">&nbsp;</td> 
<td width="113"><font color="EF9C3E"> 【 <?php echo Sinfo 


</tr> 
<tr> 
<td height="16">&nbsp;</td> 
<td><font color="910800"> 【市 场 价 : <?php echo Sinfo 


</tr> 
<tr> 
<td height="16">&nbsp;</td> 
<td><font color="DD4679"> 【会 员 价 : <?php echo Sinfo 


</tr> 
<tr> 
<td height="16">&nbsp;</td> 
<td>【<a href="lookinfo.php?id=<?php echo Sinfo[id];?>"> 查 看 信 


<tr> 
<tr> 
<td height="16">&nbsp;</td> 
<td> 【<a href="addgouwuche.php?id=<?php echo Sinfo[id];?>"> 放 


</tr> 

<tr> 
<td height="16">&nbsp;</td> 
<td><font color="13589B">【 剩 余数 量 : 


<?php 


307s 


| 


135 
136 


说 明 : 


人 Bi 项 目 业 例 分 析 


if((Sinfo[shuliang]-Sinfo[cishu])>0) 
{ 

echo (Sinfo[shuliang]-Sinfo[cishu]); 
了 


else 
echo " 已 售 完 " 5 


上 
?>】 </font></td> 
</> 
</table> 
<!-- 省 略 部 分 代码 --> 


在 附录 中 不 要 给 代码 添加 任何 效果 ， 也 不 需要 体现 过 多 注释 ， 只 需要 在 关键 代码 位 置 
给 出 文字 说 明 即 可 。 附 录 中 的 程序 尽量 保证 代码 工整 、 清 晰 易 读 、 层 次 分 明 ， 如 果 所 需要 
说 明 的 程序 不 能 在 一 个 附录 中 全 部 体现 ， 则 需要 重新 添加 附录 并 在 附录 标题 前 添加 A、B 
(大 写 英文 字母 ) 或 I、 了 I (大 写 罗马 数字 ) 以 示 区 别 ， 如 果 不 存在 其 他 附录 ， 则 不 需要 添 


加 标识 。 


8.15.2 ”附录 B 子 程序 (gouwu1.php 代码 ) 


01 
02 
03 
04 
05 


<?php 
session start|; 
if($_SESSION["usemame"]=——"") // 判 断 当前 用 户 是 否 登 录 
{ 
echo "<script>alert(' 请 先 登 录 ， 后 购物 !):historybackO:</script>"; 
exit; 
! 
> 


<?php 
include("top.php"): // 加 载 top.php 文件 
> 
<table width="800" height="438" border="0" align="center" cellpadding="0" cellspacing="0"> 
<t> 
<td width="200" height="438" valign="top" bgcolor="#E8E8E8"><div align="center"> 
<?php include("left.php"):?> 
</div></td> 
<td width="10" backeground="images/line?2.gif">&nbsp:</td> 
<td width="590" valign="top"> 
<table width="550" height="10" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td>&nbsp:</td> 
</t> 
</table> 
<table width="500" border="0" align="center" cellpadding="0" cellspacing="0"> 
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25 <form name="forml" method="post" action="gouwul.php"> 
26 <t> 
27 <td height="25" bgcolor="#555555"> 


28 <div align="center" style="color: #FFFFFF"><?php echo $_SESSION[usermame]:?> 的 购物 车 | 
</div></td> 


29 </t> 
30 <tr> 
3 <td bgcolor="#555555"><table width="500" border="0" align="center" | te 
cellpadding="0" cellsp32 acing="1"> | 
33 ”<?php | 
34 $_SESSION["total"]=""; // 注 册 SESSION 变量 并 赋 空 值 | 
35 if($_GET[qk]=="yes") // 判 断 是 否 提 交 | 
36 { | 
37 $_SESSION["producelist"]=""; /注册 SESSION 变量 并 赋 空 值 | 
38 $_SESSION["quatity"]=""; | 
39 | 
40 Sarraygwc=explode("@'",S_ SESSION[producelistj); 1// 分 离 | 
SESSION 变量 中 的 商品 | 
41 Ss-0; | 
42 for(GSi=0;Si<count(Sarraygwc);Sit+) /通过 循环 获得 商品 数量 | 
43 { | 
44 Ss+—intval(Sarraygwce[Si]); | 
45 } | 
46 if($s=—0 ) // 判 断 购物 车 是 否 为 空 | 
47 { | 
48 echo "<tr>"; | 
49 echo" <td height="25' colspan='6' bgcolor='#FFFFFF' align='center'> 您 的 购 | 
物 车 为 空 !</td>"; | 
50 echo"</tr>"; | 
51 } | 
52 else | 
53 | | 
54 > | 
55 <tr> | 
56 <td width="125" height="25" bgcolor="#FFFFFF"><div align="center"> | 
商品 名 称 </div></td> | 
57 <td width="52" bgcolor="#FFFFFF"><div align="center"> 数 量 <Jdiv></td> | 
58 <td width="64" bgcolor="#FFFFFF"><div align="center"> 市 场 价 </div></td> | 
59 <td width="64" bgcolor="#FFFFFF"><div align="center"> 会 员 价 </div></td> | 
60 <td width="51" bgcolor="#FFFFFF"><div align="center"> 折 扣 </div></td> | 
61 <td width="66" bgcolor="#FFFFFF"><div align="center"> 小 计 </div></td> | 
62 <td width="71" bgcolor="#FFFFFF"><div align="center"> 操 作 </div></td> | 
63 </t> | 
64 <?php | 
65 Stotal=0:; | 
66 S$array-explode("@".$_SESSION[producelist): 。 // 分 离 SESSION 变 | 
量 中 的 商品 | 
67 S$arrayquatity=explode("@",$ SESSION[quatity]): | 
68 while(list($name.$value)=each($_ POST)) 。 /循环 获取 POST | 
| 
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”变量 中 的 数据 
| 69 { 
| 70 for($i=0:$i<count($array)-1:$i++) 
71 { 
72 这 ($array[$i) 一 Sname) 
73 { 
74 Sarrayquatity[$i]=$value:; 
| 76 2 
| 了 } 
| 78 $ SESSION[quatity]=implode("@".$arrayquatity): 
| 79 for($i=0;$i<count($array)-1:;$i++) 
80 
81 Sid=$array[$i]: 
| 82 $num=$arrayquatity[$i]: 
| 83 if($id!="") // 如 果 获 得 色 不 为 空 
| 84 { 
| 85 $sql=mysql_query("select * from shangpin where id=".$id.™",$conn); 
| 86 // 执 行 数据 库 查 询 
| 87 Sinfo=mysql_fetch array($sq)); 
| 88 Stotall=$num*$info[huiyuanjia]: /获取 会 员 应 付 价格 
| 89 S$total+=S$totall:; 1/ 获取 总 数 
| 90 $_ SESSION["total"]=$total; /将 总 数 赋值 给 SESSION 变量 
| 91 ?> 
| 92 /省 略 部 分 代码 
| 
| 本 章 小 结 
本 章 和 第 7 章 都 是 通过 模拟 撰写 一 个 毕业 设计 〈 论 文 ) 来 向 读者 展示 如 何 分 步 完 成 毕 
| 业 设 计 论 文 )。 本 章 的 结构 和 图 书馆 管理 系统 的 毕业 设计 在 结构 上 略 有 差异 。 因 为 在 所 
| 写 毕业 设计 (论文 ) 的 过 程 中 ， 既 要 遵循 大 体 模式 , 但 也 不 要 过 于 教条 ， 要 遵循 “大 处 通 ， 
| 小 处 活 ” 的 原则 。 具 体 的 模式 与 格式 ， 还 需要 读者 根据 实际 情况 而 定 。 本 章 所 介绍 的 内 容 
| 只 是 毕业 设计 论文 ) 的 一 部 分 ， 即 正文 部 分 。 一 份 完整 的 毕业 设计 论文 )》 从 选 题 、 查 
| 找 资料 ， 到 开题 、 撰 写 论文 需要 很 长 的 时 间 ， 本 章 所 介绍 的 电子 商务 系统 毕业 设计 只 是 为 
| 读者 提供 一 个 参考 。 通 过 学 习 ， 读 者 可 以 了 解 以 下 内 容 : 
| (1) 毕业 设计 的 内 容 和 要 求 。 
| (2) 如 何 撰写 开题 报告 。 
| (3) 如 何 设计 毕业 论文 封面 。 
| (4) 如 何 撰写 毕业 论文 摘要 。 
| (5) 如 何 设 计 毕 业 论 文 目录 。 
(6) 如 何 撰写 论文 ， 从 绪论 、 开 发 工具 、 和 需求 分 析 、 数 据 库 设计 到 系统 设计 ， 再 到 
| 系统 功能 实现 。 
| (7) 如 何 编写 结论 。 
| 
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(8) 如 何 编写 参考 文献 。 
(9) 如 何 编写 致谢 和 附录 。 | 


说 明 : | AN/ 

由 于 本 章 讲 解 的 重点 是 如 何 完成 毕业 设计 的 制作 ， 所 以 没有 对 项 目的 具体 功能 实现 进 | 入 
行 系统 的 讲解 。 但 是 在 本 书 的 配套 资源 中 提供 了 该 项 目的 完整 源 代码 ， 同 时 还 配备 了 | 
完整 的 毕业 设计 论文 。 
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附录 A 


XX 师范 大 学 本 科 毕 业 论文 (设计 ) 开题 报告 


选 题 基于 PHP 的 图 书馆 管理 系统 设计 
院 系 信息 工程 学 院 专 业 计算 机 科学 与 技术 
学 生 姓名 XXX 指导 教师 XXX (职称 ) 


本 选 题 的 意义 及 在 国内 外 的 发 展 状况 : 

随 着 网 络 技术 的 高 速 发 展 和 计算 机 应 用 的 普及 , 利用 计算 机 对 图 书馆 的 日 常 工 作 进 
行 管理 势 在 必 行 。 虽然 目 前 很 多 大 型 图 书馆 已 经 有 一 整套 比较 完善 的 管理 系统 ， 但 是 在 
一 些 中 小 型 图 书馆 中 ， 大 部 分 工作 仍 需 通过 手工 完成 ， 工 作 效率 较 低 ， 管 理 员 不 能 及 时 
了 解 图 书馆 内 各 类 图 书 的 借阅 情况 , 读者 需要 的 图 书 难 以 在 短 时 间 内 找到 , 不 便于 动态 、 
及 时 地 调整 图 书 结构 。 为 了 更 好 地 适应 当前 读者 的 借阅 需求 ， 解 决 手工 管理 中 存在 的 许 
多 浆 端 ， 越 来 越 多 的 中 小 型 图 书馆 正在 逐步 向 计算 机 信息 化 管理 转变 。 

研究 内 容 : 

基于 PHP 的 图 书馆 管理 系统 原理 设计 。 

基于 PHP 的 图 书馆 管理 系统 程序 设计 。 

前 台 页 面 设计 和 软件 部 分 调试 。 

研究 方法 、 手 段 及 步骤 ， 

系统 流程 设计 : 针对 本 设计 要 求 并 配合 查阅 网 上 资料 ， 设 计 整 个 实现 流程 。 

原理 图 绘制 : 应 用 绘图 软件 绘 出 原理 图 。 

前 台 页 面 设计 : 应 用 Dreamweaver 软件 ， 结 合 JavaScript 语言 设计 前 台 界 面 。 

后 台 程序 编写 : 根据 原理 图 要 求 编程 。 

前 台 页 面 和 后 台 程 序 的 联合 调试 : 测试 已 经 完成 的 程序 , 修正 逻辑 问题 及 语法 错误 。 

参考 文献 : 

[] 邹 天 思 ， 孙 鹏 . PHP 从 入 门 到 精通 [M]. 北京 : 清华 大 学 出 版 社 ，2008. 

[2] 潘 遍 华 ， 邹 天 思 . PHP 开发 实战 宝典 [M]. 北京 : 清华 大 学 出 版 社 ，2010. 

[3] 邹 天 思 ， 潘 凯 华 ， 刘 中 华 . PHP 网 络 编程 自学 手册 [M]. 北京 : 人 民 邮 电 出 版 社 ， 
2008. 

[4] ( 美 ) Vasani. MySQL 完全 手册 [M]. 徐 小 青 ， 路 晓 村 等 译 ， 北京: 电子 工业 出 
版 社 ，2004. 

[5] 潘 凯 华 等 . PHP 项 目 开发 案例 全 程 实录 [M]. 2 版 . 北京 : 清华 大 学 出 版 社 , 2011. 
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摘 要 
入] | 
随 着 人 类 社会 的 发 展 ， 人 类 对 知识 的 需求 也 不 断 地 增长 。 在 这 种 形势 下， 书籍 就 渐渐 
| 地 成 为 人 们 获取 并 增长 知识 的 主要 途径 ， 而 图 书馆 就 自然 而 然 地 在 人 们 的 生活 中 占据 了 一 


定 的 地 位 ， 如 何 科 学 地 管理 图 书馆 不 但 关系 到 读者 求知 的 方便 程度 ， 也 关系 到 图 书馆 的 发 
展 , 因此 ,开发 一 套 完善 的 图 书馆 管理 系统 就 必 不 可 少 了 。 本 文 介绍 了 在 PHP 环境 下 采用 
“ 自 上 而 下 地 总 体 规划 ， 自 下 而 上 地 应 用 开发 ”的 策略 开发 本 系统 的 详细 过 程 ， 提 出 实现 
图 书馆 信息 管理 、 资 源 共享 的 基本 目标 ， 从 而 推动 迈 向 数字 化 图 书馆 的 步伐 ， 并 曾 述 系统 
结构 设计 和 功能 设计 ， 从 图 书 的 入 库 登 记 到 查询 浏览 ， 从 借 书 证 发 放 到 图 书 的 借阅 ， 形 成 
了 一 个 整体 自动 化 管理 模式 ， 从 软件 工程 的 角度 进行 了 科学 而 严谨 的 阐述 。 


关键 词 ， 图书 管理 借阅 浏览 PHP 


了 。374 。 


人 Abstract 


With the development of society, Mankind need more knowledge also constantly increase, 


Under this situation, book gradually become the main path to obtain the knowledge of life, and 


library naturally occupied in people certainly position, how science ground the management 
library not only relate to the convenient degree that the reader beg to know, but also relate to the 


library that strategy of development, therefore, develop the management system of a perfect | 
library can't little, this text introduced under the PHP the environment adoption “from top to | 
bottom total programming, from the detailed process that bottom but up applied development” | 
develop this system, from the step that but the push head into the arithmetic figure of the library, | 
and shows the system construction design and function design, from the books of store im | 
warehouse to register the search to view, books that issue from library card to angle of borrow, | 
become the whole automation the management the mode, and proceeds careful explain from the | 


software engineering science. 


Keywords: Library Borrow Searchtoview PHP 
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第 1 章 绪 论 


EE 


会 ，1L1 本 课题 的 开发 背景 及 意义 
11.1 设计 的 背景 


根据 对 各 学 校 图 书馆 的 调查 可 知 , 随 着 学 校 图 书馆 规模 的 不 断 扩大 , 经 营 的 图 书 品种 、 
数量 也 逐渐 增多 。 在 学 校 图 书馆 不 断 发 展 的 同时 ， 校 图 书馆 常年 采用 的 传统 的 人 工 管理 方 
式 暴露 出 了 一 些 问题 。 例 如 ， 查 找 读者 借阅 的 某 一 本 图 书 的 具体 摆 放 位 置 ， 需 要 靠 人 工 记 
忆 在 书 海中 苦 苦 查找 ， 由 于 图 书 储存 量 大 ， 很 难 准确 定位 图 书 的 具体 位 置 ， 因 此 ， 每 天 都 
要 浪费 大 量 宝贵 的 时 间 资 源 。 

1.1.2 开发 意义 


学 校 图 书馆 为 提高 工作 效率 ， 同 时 摆脱 图 书 管理 人 员 在 工作 中 出 现 的 种 种 次 端 ， 现 需 
要 委托 某 单位 开发 一 个 学 校 图 书馆 管理 系统 。 


1.2 课题 研究 内 容 


本 设计 主要 应 用 PHP 编程 、Web 开发 以 及 MySQL 数据 库 连接 等 相关 知识 。 需 要 熟练 
掌握 动态 网 页 开发 技术 ， 将 所 学 的 知识 用 于 实际 生活 中 ， 并 且 在 实际 的 生活 中 发 挥 其 主要 
功能 并 获得 效益 ， 本 设计 内 容 包括 以 下 功能 模块 : 

(1) 管理 员 管 理 模块 : 主要 包括 管理 员 登 录 、 查 看 管理 员 列 表 、 添 加 管理 员 信息 、 
管理 员 权限 设置 、 删 除 管理 员 和 更 改口 令 等 功能 。 

(2) 图 书 档案 管理 模块 ， 主 要 包括 查看 图 书 列表 、 添 加 图 书信 息 、 修 改 图 书信 息 、 
删除 图 书信 息 和 查看 图 书 详细 信息 等 功能 。 

(3) 图 书 借 还 模块 : 主要 包括 图 书 借阅 、 图 书 续 借 、 图 书 归 还 、 图 书 档案 查询 、 图 
书 借阅 查询 和 借阅 到 期 提醒 等 功能 。 


13 设计 组 织 结构 


本 毕业 设计 的 主体 主要 分 为 6 大 部 分 。 
第 1 部 分 : 即 绪论 部 分 ， 主 要 介绍 毕业 设计 论文 ) 的 开发 背景 及 意义 、 研 究 内 容 、 


| 组 织 结构 等 内 容 。 
| 第 2 部 分 : 主要 介绍 本 毕业 设计 中 所 用 到 的 开发 软件 、 运 行 环境 以 及 开发 过 程 所 需要 
| 的 结构 体系 等 要 素 。 


第 3 部 分 : 介绍 系统 的 可 行 性 分 析 及 功能 需求 等 内 容 。 
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附录 人 (SS) 
第 4 部 分 : 介绍 数据 库 的 基本 数据 表 结 构 设 计 。 
第 5 部 分 : 根据 需求 分 析 整 个 系统 的 构架 并 陈列 主要 功能 模块 。 
第 6 部 分 : 详细 讲解 各 功能 模块 的 实现 过 程 和 运行 结果 。 
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第 2 章 开发 工具 及 相关 技术 


2.1 常用 开发 工具 
2.1.1 Dreamweaver 简介 


| Dreamweaver 是 美国 Adobe 公司 开发 的 集 网 页 制作 和 管理 网 站 于 一 体 的 “所 见 即 所 得 ” 
| 网 页 编辑 器 ， 它 是 第 一 套 针 对 专业 网 页 设计 师 特 别 发 展 的 视觉 化 网 页 开发 工具 ， 利 用 它 可 
| 以 轻而易举 地 制作 出 跨越 平台 限制 和 浏览 器 限制 的 充满 动感 的 网 页 。 

| Dreamweaver、Flash 以 及 在 Dreamweaver 之 后 推出 的 针对 专业 网 页 图 像 设 计 的 
| Fireworks， 被 Adobe 公司 称 为 Dreamteam 〈 梦 之 队 )， 足 见 市 场 的 反响 和 Adobe 公司 对 它 
| 们 的 自信 。 说 到 Dreamweaver， 读 者 应 该 了 解 一 下 网 页 编辑 器 的 发 展 过 程 ， 随 着 互联 网 
| (Intemet) 的 家 喻 户 晓 ，HTML 技术 的 不 断 发 展 和 完善 ， 产生 了 众多 网 页 编辑 器 ， 根 据 网 
| 页 编辑 器 的 基本 性 质 不 同 ， 可 以 将 其 分 为 所 见 即 所 得 网 页 编辑 器 和 非 所 见 即 所 得 网 页 编辑 
| 器 〈 即 原始 代码 编辑 器 )， 两 者 各 有 千秋 。 所 见 即 所 得 网 页 编辑 器 的 优点 是 直观 、 使 用 方 
| 便 、 容 易 上 手 。 

| Dreamweaver 可 以 用 最 快捷 的 方式 将 Fireworks、FreeHand 或 Photoshop 等 档案 移 至 网 
| 页 上 。 使 用 检 色 吸管 工具 选择 屏幕 上 的 颜色 可 设 定 最 接近 的 网 页 安全 色 。 对 于 选单 、 快 捷 
| 键 与 格式 控制 ， 都 只 要 一 个 简单 步 又 便 可 完成 。Dreamweaver 能 与 用 户 喜 爱 的 设计 工具 ， 

| 如 Playback Flash、Shockwave 和 外 挂 模 组 等 搭配 ， 不 需 离开 Dreamweaver 便 可 完成 ， 整体 
| 运用 流程 自然 顺畅 。 除 此 之 外 ， 只 要 单 击 便 可 使 Dreamweaver 自动 开启 Firework 或 
| Photoshop 来 进行 编辑 与 设 定 文件 的 最 佳 化 。 

| 2.1.2 Zend Development Environment (ZDE) 简介 


| Zend Development Environment 是 Zend 公司 推出 的 一 款 PHP 的 IDE 也 是 在 Linux 下 面 
| 唯一 一 个 PHP 的 集成 开发 调试 环境 ， 当 然 它 也 有 Windows 版 本 。 和 其 他 IDE 不 同 ，ZDE 是 
| 用 Java 编写 的 ， 这 不 光 意 味 着 多 平台 性 ， 同 时 意味 着 给 用 户 在 使 用 上 带 来 很 多 不 便 。 

| ZDE 提供 的 功能 是 最 齐全 的 ， 而 且 可 以 和 Zend 公司 的 其 他 PHP 开发 工具 无 缝 结合 
| 成 为 一 套 强大 的 PHP 开发 环境 , 而且 ZDE 的 调试 环境 是 建 在 ZDE 自身 程序 里 面 的 ， 而 不 
| 像 其 他 的 IDE， 是 通过 PHP Debuger 来 实现 的 。 

| ZDE 的 特征 为 语法 加 亮 、 完 整齐 全 的 函数 补 全 和 帮助 〈 但 只 针对 PHP 内 建 函 数 ， 对 
| 自 定义 函数 无 效 )、 工 程 管理 ， 还 有 ZDE 独 有 的 PHP 代码 整理 、PHPini 可 视 化 编辑 和 嵌 
| 套 标示 ， 使 用 后 者 查看 结构 复杂 的 程序 十 分 方便 ， 再 不 用 去 数 密密麻麻 的 “{} ”号 了 。 

| 提供 的 Debug 功能 包括 breakpoints、stack、watches、variables、output buffer 以 及 所 
| 有 该 有 的 跟踪 方式 。 
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2.13 PHPED 


PHPED 的 综合 性 能 是 最 好 的 ， 启 动 速度 很 快 ， 提 供 的 功能 也 最 多 ， 包 括 语法 加 亮 、 | 
函数 补 全 、 工 程 管理 、 代 码 模版 、 自 动 代码 补 全 、 可 视 化 的 数据 库 管理 ,内置 DAV、CVS、| 
FTP、WEBSERVER、DEBUGGER 以 及 JS 代码 列表 ， 常 见 HTML 标签 集 ， 另 外 PHPED | 
还 支持 插件 技术 。 | 

安装 版 还 附带 了 PHP 和 MySQL 的 手册 (英文 版 )。 值 得 一 提 的 是 PHPED 的 调试 功能 ， ， 
虽然 ZDE 有 它 所 有 的 调试 功能 ， 但 是 PHPED 更 方便 ， 如 调试 时 将 鼠标 光标 放 在 变量 上 就 | 
可 以 直接 看 到 变量 的 值 ， 而 且 调试 窗口 的 分 布 较 细致 和 合理 ， 支 持 外 部 脚本 调试 ，ZDE 虽 | 
然 也 能 实现 ， 但 设置 起 来 比较 麻烦 。 | 

PHPED 的 脚本 结构 功能 和 ZDE 大 体 相 同 ， 不 过 在 对 类 方面 细致 到 了 类 元 素 ， 所 以 效 | 
果 要 略 胜 一 筹 。 但 PHPED 的 缺点 也 是 致命 的 ， 那 就 是 它 对 中 文 的 支持 很 差 ， 甚 至 在 选取 | 
时 都 会 显示 不 正常 。 另 外 值得 一 提 的 是 ， 调 试 时 变量 值 中 文 显示 可 以 通过 在 DEBUGGER | 
里 面 的 设置 (将 语言 改 成 GB)， 否 则 在 网 页 输出 中 文 时 可 能 会 导致 异常 。 | 


2.2 运行 环境 


2.2.1 PHP 5.0 


2004 年 7 月 13 日 ，PHP 5.0 发 布 。 该 版 本 以 Zend 引擎 工 为 引擎 ， 且 加 入 了 新 功能 ， | 
如 PHP Data Objects (PDO)。 现 在 PHP 5.0 版 本 强化 更 多 的 功能 。 首 先 ， 完 全 实现 面向 对 | 
象 , 提供 名 为 PHP 兼容 模式 的 功能 。 其 次 是 XML 功能 , PHP 5.0 版 本 支持 直观 地 访问 XML | 
数据 、 名 为 SimpleXML 的 XML 处 理 界面 。 同 时 还 强化 了 XML Web 服务 支持 ， 而 且 标准 | 
支持 SOAP 扩展 模块 。 数 据 库 方面 , PHP 新 版 本 提供 旨 在 访问 MySOL 的 新 界面 一 MySQL。 | 
除 此 前 的 界面 外 ,还 可 以 使 用 面向 对 象 界面 和 预 处 理 语句 (Prepared Statement) 等 MySQL | 
的 新 功能 。 另 外 ，PHP 5.0 上 还 捆绑 有 小 容量 RDBMS-SQLite。 | 
(1) 新 的 对 象 模式 (New Object Mode) | 
PHP5 中 的 对 象 已 经 进行 了 较 系 统 、 全 面 的 调整 ， 现 在 类 似 于 Java。 本 小 节 着 重 讲述 | 
PHP5 中 新 的 对 象 模式 ， 并 举例 说 明 。 | 
@ 构造 函数 和 析 构 函数 | 

在 PHP 4.0 中 ， 当 函数 与 对 象 同名 时 ， 该 函数 将 成 为 该 对 象 的 构造 函数 ， 并 没有 析 构 | 
函数 的 概念 。 | 
在 PHP 5.0 中 ， 构 造 函数 被 统一 命名 为 “constmct， 并 且 引 入 了 析 构 函数 的 概念 , 被 | 
统一 命名 为 _ destruct。 | 
@ 对 象 的 引用 | 

在 PHP 4.0 中 ， 传 递 变量 给 一 个 函数 或 方法 ， 实 际 是 把 该 变量 复制 一 次 ， 也 就 意味 着 | 

用 户 传 给 函数 或 方法 的 是 这 个 变量 的 一 个 副本 ， 除 非 用 户 使 用 了 引用 符号 “&” 来 声明 是 | 
要 作 一 个 引用 ， 而 不 是 一 次 复制 。 在 PHP 5.0 中 ， 对 象 总 是 以 引用 的 形式 存在 的 ， 对 象 中 | 
的 赋值 操作 同样 也 都 是 一 个 引用 操作 。 | 
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可 
@ 对 象 的 克隆 
当 一 个 对 象 始终 以 引用 的 形式 来 被 调用 时 ， 若 想得到 该 对 象 的 一 个 副本 ， 该 怎么 办 ? 
| PHP 5.0 提供 了 一 个 新 的 功能 ， 就 是 对 象 的 克隆 ， 语 法 为 _clone。 
公克” ” @ 对 象 中 的 私有 、 公 共 及 保护 模式 

| PHP 4.0 中 ， 一 个 对 象 的 所 有 方法 和 变量 都 是 公共 的 ， 这 意味 着 用 户 可 以 在 一 个 对 象 
的 外 部 操作 其 中 的 任意 一 个 变量 和 方法 。PHP 5.0 引入 了 3 种 新 的 用 来 控制 这 种 存 取 权限 
的 模式 ， 分 别 是 公共 的 〈Public)、 受 保护 的 〈Protected) 及 私有 的 〈Private) 模式 。 

口 ”公共 模式 (Public) : 允许 在 对 象 外 部 进行 操作 控制 。 

口 私有 模式 (Private) : 只 允许 本 对 象 内 的 方法 对 其 进行 操作 控制 。 

口 ” 受 保护 模式 (Protected) : 允许 本 对 象 及 其 父 对 象 对 其 进行 操作 控制 。 

人 @ 接口 (Interfaces) 

PHP 4.0 中 的 对 象 支持 继承 ， 要 使 一 个 对 象 成 为 另 一 个 对 象 的 派生 类 ， 用 户 需要 使 用 
类 似 class foo extends parent 的 代码 来 控制 。PHP 4.0 和 PHP 5.0 中 ， 一 个 对 象 都 仅 能 继承 
一 次 ， 多 重 继承 是 不 被 支持 的 。 不 过 ， 在 PHP 5.0 中 产生 了 一 个 新 的 名 词 一 一 接口 。 接 口 
是 一 个 没有 有 具体 处 理 代码 的 特殊 对 象 ， 它 仅仅 定义 了 一 些 方法 的 名 称 及 参数 ， 此 后 的 对 象 
就 可 以 方便 地 使 用 implement 关键 字 把 需要 的 接口 整合 起 来 , 然后 再 加 入 具体 的 执行 代码 。 

这 对 提高 代码 的 可 读 性 及 通俗 性 有 很 大 的 帮助 ， 通 过 上 面 的 例子 可 以 看 到 ， 对 象 foo 
包含 了 displayable 和 printable 两 个 接口 ， 这 时 就 可 以 清楚 地 知道 ， 对 象 foo 一 定 会 有 一 个 
| display0 方 法 和 一 个 print0 方 法 , 只 需要 去 了 解 接 口 部 分 , 用 户 就 可 以 轻易 地 操作 该 对 象 而 
不 必 去 关心 对 象 的 内 部 是 如 何 运作 的 。 

@ 抽象 类 

抽象 类 不 能 被 实例 化 ， 与 其 他 类 一 样 ， 允 许 定义 变量 及 方法 。 

抽象 类 同样 可 以 定义 一 个 抽象 的 方法 ， 抽 象 类 的 方法 不 会 被 执行 ， 不 过 将 有 可 能 会 在 
其 派生 类 中 执行 。 

@ _call0 方 法 

PHP 5.0 的 对 象 新 增 了 一 个 专用 方法 _call0, 该 方法 用 来 监视 一 个 对 象 中 的 其 他 方法 。 
| 如 果 用 户 试 图 调用 一 个 对 象 中 不 存在 的 方法 ，_call0 方 法 将 会 被 自动 调用 。 
| _set 和 _get 方法 
_set 和 _get 方法 可 以 用 来 捕获 一 个 对 象 中 不 存在 的 变量 和 方法 。 

@ 类 型 指示 

在 PHP 5.0 中 ， 用 户 可 以 在 对 象 的 方法 中 指明 其 参数 必须 为 另 一 个 对 象 的 实例 。 

静态 成 员 

静态 成 员 和 静态 方法 在 面向 对 象 编程 的 术语 中 被 称 作 类 方法 〈class methods) 和 类 变 
| 量 (class variables)。 

(2) 异常 处 理 (Exceptions) 

| 异常 处 理 是 公认 的 处 理 程序 错误 的 理想 方法 ， 在 Java 及 C 中 都 有 这 个 概念 ， 令 人 欣 
| 喜 的 是 ， 在 PHP 5.0 中 已 经 加 入 了 这 方面 的 应 用 。 用 户 可 以 尝试 使 用 try 和 catch 来 控制 程 
| 序 的 错误 。 当 有 错误 发 生 的 时 候 ， 代 码 会 把 错误 交 给 catch 子 句 来 处 理 ， 在 catch 子 句 中 ， 
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用 户 需 要 指明 要 把 错误 交 给 某 个 对 象 处 理 ， 这 样 做 可 以 使 代码 结构 看 起 来 更 清晰 ， 因 为 现 | 
在 ， 调 试 者 可 以 把 所 有 的 错误 信息 交 给 一 个 对 象 来 处 理 。 | 
(3) 自 定义 错误 处 理 
用 户 可 以 很 方便 地 用 自 定义 的 处 理 错误 的 代码 来 控制 程序 中 的 意外 。 用 户 仅 需 要 从 异 | 
常 类 中 派生 出 一 个 自己 的 错误 控制 类 ， 在 其 错误 控制 类 中 ， 需 要 有 一 个 构造 函数 和 一 个 | 
getMessage() 方 法 。 
(4) 名 称 空间 (Namespace) | 
名 称 空间 对 类 的 分 组 或 函数 分 组 很 有 用 。 它 可 以 把 一 些 相关 的 类 或 函数 给 组 合 到 一 | 
起 ， 方 便 以 后 调用 。 例 如 : | 
01 <?php 
02 namespace Math 
p30 
04 class Complex 
O50 
06 /...code... 
07 function _constructO 
08 { 
09 print("hey"); 
on 
nn 
To) 
13 $m=newMath::Complex(O; 
14 ?> | 
在 实际 运用 中 ， 用 户 可 能 会 需要 声明 两 个 或 多 个 名 称 一 样 的 对 象 来 做 不 同 的 事情 , 那 | 
么 就 可 以 把 它们 分 别 放 到 不 同 的 名 称 空 间 中 去 〈 但 接口 是 要 相同 的 )。 | 


2.2.2 Apache 


Apache 是 世界 使 用 排名 第 一 的 Web 服务 器 软件 。 由 于 其 跨 平台 性 和 安全 性 ， 它 可 以 | 
运行 在 几乎 所 有 广泛 使 用 的 计算 机 平台 上 ， 是 最 流行 的 Web 服务 器 端 软件 之 一 。 

Apache 源 于 NCSAhttpd 服务 器 ， 经 过 多 次 修改 ， 成 为 世界 上 最 流行 的 Web 服务 器 软 | 
件 之 一 。Apache 取 自 a patchy server 的 读音 ， 意 思 是 充满 补丁 的 服务 器 ， 因 为 它 是 自由 软 | 
件 ， 所 以 不 断 有 人 来 为 它 开发 新 的 功能 、 新 的 特性 ， 修 改 原来 的 缺陷 。Apache 的 特点 是 简 | 
单 、 速 度 快 、 性 能 稳定 ， 并 可 作为 代理 服务 器 来 使 用 。 | 

Apache 原本 只 用 于 小 型 或 试验 Internet 网 络 ， 后 来 逐步 扩充 到 各 种 UNIX 系统 中 , 尤 | 
其 对 Linux 的 支持 相当 完美 。Apache 有 多 种 产品 ， 可 以 支持 SSL 技术 ， 支 持 多 个 虚拟 主 | 
机 。Apache 是 以 进程 为 基础 的 结构 ， 进 程 要 比 线程 消耗 更 多 的 系统 开支 ， 不 太 适合 于 多 处 
理 器 环境 ， 因 此 ， 在 一 个 Apache Web 站 点 扩容 时 ， 通 常 是 增加 服务 器 或 扩充 群集 节点 而 | 
不 是 增加 处 理 器 。 到 目前 为 止 ， Apache 仍然 是 世界 上 使 用 最 多 的 Web 服务 器 ， 市 场 占 有 ， 
率 达 60% 左 右 。 世 界 上 很 多 著名 的 网 站 , 如 Amazon、Yahoo!、W3 Consortium、Financial Times | 
等 都 是 Apache 的 产物 ， 其 成 功 之 处 主要 在 于 它 的 源 代码 开放 、 有 一 支 开 放 的 开发 队伍 、 
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支持 跨 平 台 的 应 用 〈 可 以 运行 在 几乎 所 有 的 UNIX、Windows、Linux 系统 平台 上 ) 以 及 具 
有 可 移植 性 等 方面 。 

Apache 的 诞生 极 富 戏剧 性 . 当 NCSAWWAW 服务 器 项 目 停顿 后 ,那些 使 用 NCSA WWW 
服务 器 的 用 户 开始 交换 他 们 用 于 该 服务 器 的 补丁 程序 ,他 们 也 很 快 认识 到 成 立 管理 这 些 补 
丁 程 序 的 论坛 是 必要 的 。 就 这 样 ,， 诞生 了 Apache Group， 后 来 该 团体 在 NCSA 的 基础 上 创 
建 了 Apache。 


2.2.3 MySQL 
MySQL 是 一 个 小 型 关系 型 数据 库 管理 系统 ， 开 发 者 为 瑞典 MySQL AB 公司 。 该 公司 


在 2008 年 1 月 16 日 被 Sun 公司 收购 ,而 2009 年 , Sun 公司 又 被 Oracle 收购 ,对 于 MySQL 
| 的 前 途 ， 没 有 人 持 乐 观 的 态度 。 目 前 MySQL 被 广泛 地 应 用 在 Intemet 上 的 中 小 型 网 站 中 。 
| 由 于 其 体积 小 、 速 度 快 、 总 体 拥有 成 本 低 ， 尤 其 是 开放 源码 这 一 特点 ， 许 多 中 小 型 网 站 为 
了 降低 网 站 总 体 拥有 成 本 而 选择 了 MySQL 作为 网 站 数据 库 。 


2.2.4 运行 环境 的 搭建 
搭建 运行 环境 的 操作 步骤 如 下 : 
(1) 通过 互联 网 下 载 Apache、PHP、MySQL 的 软件 安装 包 。 
(2) 双击 Apache 2.2.8-win32-x86-no_sslmsi 文件 弹出 欢迎 界面 (这 里 以 2.2.8 版 本 为 


| 例 )。 单 击 Next 按钮 直至 进入 Server Information 页 。 在 服务 器 信息 页 ， 用 户 需要 根据 自身 情况 
| 填写 用 户 资料 。 然 后 单 击 Next 按钮 继续 选择 安装 类 型 和 路 径 。 继 续 单 击 Next 按钮 直 至 安装 完成 。 
| 完成 安装 后 启动 Apache 即 可 完成 Apache 服务 器 的 配置 工作 。 


(3) 将 PHP 5.0 的 安装 文件 php-5.2.5-Win32.zip 解压 到 相应 目录 下 (这 里 以 5.2.5 版 


| 本 为 例 )。 在 php 5.0 文件 夹 下 和 ext 文件 夹 下 找到 libmysqLdll、mbsthing dll、mysqlLdll 和 
| phpsts_dll 文件 ， 并 复制 到 系统 盘 Windows\system32 目录 下 。 然 后 将 文件 php inirdist 复制 
| 到 系统 盘 \Windows 目录 下 ， 并 重新 命名 为 php.ini。 找 到 “:;extension=php_mysql.dll” 这 一 
| 行 ， 将 前 面 的 分 号 “;” 去 掉 。 这 样 ，PHP 就 可 以 支持 MySQL 数据 库 了 。 如 果 需 要 加 载 其 
| 他 模块 ， 方 法 是 相同 的 。 保 存 后 ， 重 新 启动 Apache 服务 器 。 


(4) 双击 MySQL 安装 文件 mysql-essential-5.0.51-win32.msi 进入 欢迎 界面 (这 里 以 
5.0.51 版 本 为 例 )。 选 择 相关 配置 ， 单 击 “Next” 按 钮 直至 MySQL 安装 结束 。 

(5) 配置 Apache 服务 器 和 PHP 5.0。 用 户 可 以 通过 修改 Apache 根 目录 下 conf 目录 
中 的 httpd.conf 文件 ， 使 Apache 可 以 解析 PHP 文件 。 


2.3 ”相关 技术 


2.3.1 PHP 的 工作 原理 及 相关 技术 


PHP (HyperText Preprocessor) 是 一 种 多 平台 无 颖 运行 的 服务 器 端 伴 入 式 脚本 语言 ， 
融合 了 C、Java 和 Perl 等 编程 语言 ， 由 于 它 是 一 种 免费 的 软件 ， 具 有 自由 软件 的 性 质 ， 版 
本 更 新 速度 快 、 移 植 速度 快 ， 并 具有 丰富 的 函数 库 功 能 ， 因 而 很 快 得 到 用 户 认 可 ， 特 别 是 
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PHP 提供 加 密 函 数 库 ， 适 合 对 安全 性 要 求 较 高 的 电子 商务 网 站 ， 在 Apache 环境 下 构建 的 ， 
PHP 网 站 已 经 成 为 当前 流行 的 Web 网 站 之 一 。 
PHP 能 够 作为 Apache Web 服务 器 的 模块 执行 ， 使 得 它 的 执行 效率 要 高 于 普通 的 CGI | 
程序 ， 而 且 能 比 CGI 或 者 Perl 更 快速 地 执行 动态 网 页 。 | 
使 用 者 如 果 创建 了 一 个 PHP 应 用 程序 ， 实 际 上 相当 于 创建 了 一 个 PHP 脚本 文件 。 在 | 
服务 器 将 输出 信息 发 送 到 客户 端 之 前 ,网 络 服务 器 会 率先 将 文件 中 的 PHP 语言 进行 加 工 处 | 
理 。 如 果 服 务 器 不 支持 PHP， 通 常情 况 下 ， 网 络 服务 器 会 直接 将 超 文本 文件 送 到 客户 的 浏 | 
览 器 上 以 表示 对 HTTP 的 要 求 作出 应 答 ， 如 果 服 务 器 支持 PHP， 则 在 服务 器 响应 一 个 对 | 
PHP 文件 的 请 求 时 ， 进 行 下 列 处 理 ， 首 先 在 一 个 PHP 文件 内 ， 标 准 的 HTML 编码 会 被 直 | 
接送 到 浏览 器 上 ,而 内 嵌 PHP 程序 却 是 先 被 网 络 服务 器 解释 执行 。 如 果 是 标准 输出 ， 输出 | 
信息 也 将 作为 标准 的 HTML 而 被 送 至 浏览 器 。 | 
PHP 可 以 安装 在 UNIX/Linux 环境 下 ， 也 可 以 安装 在 Windows 环境 下 。 目 前 网 站 使 用 | 
最 多 的 、 最 理想 的 便 是 PHP+MySQL+Apache 基于 UNIX/Linux 下 的 服务 器 策略 。 | 
2.3.2 JavaScript 语言 


JavaScript 是 一 种 基于 对 象 和 事件 驱动 并 具有 相对 安全 性 的 客户 端 脚本 语言 。 同 时 也 | 
是 一 种 广泛 用 于 客户 端 Web 开发 的 脚本 语言 ， 常 用 来 给 HTML 网 页 添加 动态 功能 ， 如 响 | 
应 用 户 的 各 种 操作 。 它 最 初 由 Netscape 公司 的 Brendan Eich 设计 ， 是 一 种 动态 、 弱 类 型 、 | 
基于 原型 的 语言 ,内置 支持 类 。JavaScript 是 Sun 公司 的 注册 商标 。 Ecma 国际 以 JavaScript | 
为 基础 制定 了 ECMAScript 标准 。JavaScript 也 可 以 用 于 其 他 场合 ， 如 服务 器 端 编程 。 完 整 | 
的 JavaScript 实现 包含 3 个 部 分 : ECMAScript、 文档 对 象 模 型 和 字 节 顺序 记号 。 | 

Netscape 公司 在 最 初 将 其 脚本 语言 命名 为 LiveScript， 后 来 Netscape 在 与 Sun 合作 之 | 
后 将 其 改名 为 Java Script。JavaScript 最 初 是 受 Java 启发 而 开始 设计 的 , 目的 之 一 就 是 “看 | 
上 去 像 Java”， 因 此 语法 上 有 类 似 之 处 ， 一 些 名 称 和 命名 规范 也 借 自 Java。 但 JavaScript | 
的 主要 设计 原则 源 自 Self 和 Scheme。JavaScript 与 Java 名 称 上 的 近似 ， 是 当时 Netscape | 
公司 出 于 营销 考虑 与 Sun 公司 达成 协议 的 结果 。 为 了 取得 技术 优势 ， 微 软 推出 了 JScript | 
来 迎战 JavaScript 的 脚本 语言 。 为 了 互 用 性 ，Ecma 国际 (前 身 为 欧洲 计算 机 制造 商 协会 》 | 
创建 了 ECMA-262 标准 ECMAScript)。 现 在 两 者 都 属于 ECMAScript 的 实现 。 尽 管 | 
JavaScript 是 作为 给 非 程序 人 员 的 脚本 语言 ， 而 不 是 作为 给 程序 人 员 的 编程 语言 来 推广 和 | 
宣传 ， 但 是 JavaScript 具有 非常 丰富 的 特性 。 | 


2.3.3 CSS 样式 表 


CSS (Cascading Style Sheet， 层 合 样 式 表 或 级 联 样式 表 ) 是 一 组 格式 设置 规则 ， 用 于 
控制 Web 页 面 的 外 观 。 通 过 使 用 CSS 样式 设置 页 面 的 格式 ， 可 将 页 面 的 内 容 与 表现 形式 | 
分 离 。 页 面 内 容 存 放 在 HTML 文档 中 ， 而 用 于 定义 表现 形式 的 CSS 规则 则 存放 在 另 一 个 | 
文件 中 或 HTML 文档 的 某 一 部 分 ， 通 常 为 文件 头 部 分 。 将 内 容 与 表现 形式 分 离 ， 不 仅 | 
可 使 维护 站 点 的 外 观 更 加 容易 ， 而 且 还 可 以 使 HTML 文档 代码 更 加 简练 ， 缩 短 浏 览 器 的 | 
加 载 时 间 。 | 
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pp 

可 
| 2.4 ”B/S 结构 简介 

| B/S (Browser/Server， 浏 览 器 /服务 器 结构 是 Web 兴起 后 的 一 种 网 络 结构 模式 ，Web 

贪 站 | 浏览 器 是 客户 端 最 主要 的 应 用 软件 。 这 种 模式 统一 了 客户 端 ， 将 系统 功能 实现 的 核心 部 分 

”| 集中 到 服务 器 上 ， 简 化 了 系统 的 开发 、 维 护 和 使 用 。 客 户 机 上 只 要 安装 一 个 浏览 器 

(Browser), 如 Netscape Navigator 或 Internet Explorer, 服务 器 安装 Oracle、 Sybase、 Informix 

| 或 SQL Server 等 数据 库 。 浏 览 器 通过 Web Server 同 数 据 库 进行 数据 交互 。B/S 结构 如 


| 图 21 所 示 。 
| 转 


MEB 服 务 器 数据 库 服务 器 


园 员 呈 ee 四 


客户 机 1 客户 机 2 客户 机 3 客户 机 N 


图 2.1 B/S 结构 图 
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第 3 章 需求 分 析 


3.1 可 行 性 分 析 


3.1.1 系统 的 必要 性 


通过 计算 机 对 图 书 进行 管理 ， 不 仅 为 图 书馆 的 管理 注入 了 新 的 生机 ， 而 且 在 运营 过 程 | 
中 节省 了 大 量 的 人 力 、 物 力 、 财 力 和 时 间 ， 可 以 提高 图 书馆 的 管理 效率 ， 还 为 图 书馆 在 读 | 
者 群 中 树立 了 一 个 全 新 的 形象 ， 为 图 书馆 的 日 后 发 展 莫 定 了 一 个 良好 的 基础 。 随 着 计算 机 | 
技术 的 发 展 以 及 计算 机 在 各 企 事 业 单 位 中 应 用 的 普及 ,计算 机 强大 的 功能 已 为 人 们 深刻 认 | 
识 。 它 在 当今 高 速 发 展 的 信息 时 代 占 据 着 不 可 或 缺 的 地 位 , 作为 计算 机 应 用 软件 的 一 部 分 ，| 
使 用 计算 机 对 图 书馆 进行 综合 管理 已 经 远 远 超过 手工 管理 的 效率 。 因 此 ， 开 发 这 样 一 个 管 | 
理 系统 是 很 有 必要 的 。 | 

3.1.2 系统 的 可 行 性 


动态 网 络 技术 的 主流 可 以 分 为 PHP 技术 、JSP 技术 和 .NET 技术 。 这 3 种 Web 开发 语 
言 都 可 以 完美 地 实现 图 书馆 管理 系统 的 软件 编制 ， 而 目前 存在 的 各 种 网 络 终端 服务 器 也 具 | 
备 运 行 该 系统 的 条 件 。 本 系统 采用 了 开源 性 较 好 且 易 于 开发 和 维护 的 PHP 语言 , 利用 当前 | 
网 站 流行 的 构架 方式 (Apache+MySQL+PHP)， 并 应 用 Windows 作为 搭载 平台 建立 整个 系 | 
统 的 Web 服务 器 。 由 于 Apache、MySQL 与 PHP 具有 较 好 的 兼容 性 ， 并 且 都 同属 于 开放 | 
源 软件 (FLOSS)， 因 此 ， 在 低 投入 甚至 零 投 入 的 前 提 下 也 可 以 很 好 地 建立 起 一 个 稳定 、 | 
安全 、 免 费 的 网 络 管理 系统 。 


3.2 系统 需求 


根据 学 校 图 书馆 管理 系统 的 特点 , 可 以 将 其 分 为 系统 设置 、 读 者 管理 、 图 书 档案 管理 、 
图 书 借 还 和 系统 查询 5 个 部 分 ， 其 中 各 部 分 及 其 包括 的 具体 功能 模块 如 图 3.1 所 示 。 


| 学 校 图 书馆 管理 系统 | 


施 宣 污水 铀 刻 
吓 漆 六 阐 中 一 
哺 泪 滋 由 

赐 泪 港 落 

宣 济 薄 硬 

瀛 口 汇 问 


病 嘻 屹 准 总 妆 


及 嘻 兴 节 剖 闻 
寺内 画 覃 贡 末 
三 漂 洪 此 画 赤 


图 3.1 学 校 图 书馆 管理 系统 功能 结构 图 
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Ee 功能 需求 


”通过 对 一 些 大 型 图 书馆 的 实际 考察 、 分 析 , 并 结合 图 书馆 的 要 求 以 及 实际 的 市 场 调查 
全 A | 要 求 本 系统 具有 以 下 功能 : 
| (1) 网 站 设计 页 面 要 求 美观 大 方 、 个 性 化 ， 功 能 全 面 ， 操 作 简单 。 
(2) 要 求实 现 基础 信息 的 管理 平台 。 
| (3) 要 求 对 所 有 读者 进行 管理 。 
(4) 要 求实 现 图 书 借阅 排行 ， 了 解 当前 的 畅销 书 。 
(5) 商品 分 类 详尽 ， 可 按 不 同类 别 查看 图 书信 息 。 
| (6) 提供 快速 的 图 书信 息 、 图 书 借阅 检索 功能 ， 保 证 数据 查询 的 灵活 性 。 
| (7) 实现 图 书 借阅 、 图 书 续 借 、 图 书 归还 功能 。 
| (8) 实现 综合 条 件 查询 ， 如 按 用 户 指定 条 件 查询 、 按 日 期 时 间 段 查询 、 按 综合 条 件 
| 查询 等 。 
| (9) 要 求 图 书 借阅 、 续 借 、 归 还 时 记 下 每 一 笔记 录 的 操作 员 。 
| (10) 实现 对 图 书 借阅 、 续 借 和 归还 过 程 的 全 程 数据 信息 跟踪 。 
| (11) 提供 借阅 到 期 提醒 功能 ， 使 管理 者 可 以 及 时 了 解 到 已 经 到 达 归 还 日 期 的 图 书 借 
| 阅 信息 。 
| (12) 提供 灵活 、 方 便 的 权限 设置 功能 ， 使 整个 系统 的 管理 分 工 明确 。 
| (13) 具有 易 维 护 性 和 易 操作 性 。 


| 3.4 性 能 要 求 


根据 前 面 所 作 的 需求 分 析 及 功能 的 需求 可 以 得 出 ， 学 校 图 书馆 管理 系统 实施 后 ， 应 达 
到 以 下 系统 性 能 标准 : 
| (1) 网 站 设计 页 面 要 求 美观 大 方 、 功 能 全 面 ， 操 作 简单 。 
| (2) 网 站 整体 结构 和 操作 流程 合理 顺畅 ， 实 现 人 性 化 设计 。 
| (3) 规范 、 完 善 的 基础 信息 设置 。 
| (4) 对 操作 员 设置 不 同 的 操作 权限 ， 为 管理 员 提 供 修改 权限 功能 
| (5) 对 所 有 读者 进行 集中 管理 。 
| (6) 对 图 书信 息 进行 集中 管理 。 
| (7) 实现 图 书 借阅 排行 ， 以 便 了 解 当前 的 畅销 书 。 
(8) 提供 快速 的 图 书信 息 、 图 书 借阅 检索 功能 
(9) 实现 图 书 借阅 、 图 书 续 借 、 图 书 归还 功能 
(10》 实现 综合 条 件 查询 ， 如 接 用 户 指定 条 件 查 询 、 接 日 期 时 间 段 查询 、 按 综合 条 件 
| 查询 等 。 
| (11) 实现 图 书 借阅 、 续 借 、 归 还 时 记 下 每 一 笔记 录 的 操作 员 。 
(12) 支持 图 书 到 期 提醒 功能 。 
(13) 为 操作 员 提供 密码 修改 功能 。 
(14) 系统 运行 稳定 、 安 全 可 靠 。 
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第 4 章 系统 数据 库 设计 


4.1 数据 库 概述 


计算 机 信息 系统 以 数据 库 为 核心 ， 在 数据 库 管理 系统 的 支持 下 ， 进 行 信息 的 收集 、 整 | 
理 、 存 储 、 检 索 、 更 新 、 加 工 、 统 计 和 传播 等 操作 。 
对 于 数据 库 应 用 开发 人 员 来 说 ， 为 使 现实 世界 的 信息 流 计算 机 化 ， 并 对 计算 机 化 的 信 | 
息 进行 各 种 操作 ， 就 是 如 何 利用 数据 库 管 理 系统 、 系 统 软件 和 相关 硬件 系统 ， 将 用 户 的 要 | 
求 转化 成 有 效 的 数据 结构 ， 并 使 数据 库 结构 易于 实现 用 户 新 的 要 求 的 过 程 。 

确切 地 说 ， 数 据 库 设计 是 指 对 于 一 个 给 定 的 应 用 环境 ， 提 供 一 个 确定 最 优 数据 模型 与 | 
处 理 模 式 的 地 辑 设计 ， 以 及 一 个 确定 数据 库存 储 结构 与 存 取 方法 的 物理 设计 ， 建 立 起 既 能 | 
反映 现实 世界 信息 和 信息 联系 ， 满 足 用 户 数据 要 求 和 加 工 要 求 ， 又 能 被 某 个 数据 库 管理 系 
统 所 接受 ， 同 时 能 实现 系统 目标 ， 并 有 效 存 取 数据 的 数据 库 。 

所 谓 数据 库 是 指 以 一 定 的 组 织 方式 存储 在 一 起 的 、 能 为 多 个 用 户 所 共享 的 、 与 应 用 程 | 
序 彼此 独立 的 相关 联 的 数据 集合 。 而 数据 库 系统 是 指 实现 有 组 织 的 动态 的 存储 大 量 关联 数 | 
据 ， 支 持 多 用 户 访问 的 计算 机 软 硬 件 资源 与 数据 库 管 理 员 组 成 的 系统 。 个 人 系统 是 按 用 户 | 
的 需求 进行 数据 库 定义 、 存 取 、 运 行 、 建 立 和 维护 功能 的 ， 系 统 的 数据 库 定义 模型 如 图 41 | 
所 示 。 


图 4.1 数据 库 定义 模型 图 


4.2 系统 实体 E-R 图 
1， 图 书 档案 实体 


图 书 档案 实体 包括 编号 、 条 形 码 、 书 名 、 类 型 、 作 者 、 译 者 、 出 版 社 、 价 格 、 页 码 、 
书架 、 输 入 时 间 和 操作 员 等 属性 。 图 书 档案 实体 的 E-R 图 如 图 4.2 所 示 。 
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图 4.2 图 书 档案 实体 E-R 图 
2. 读者 档案 实体 
| 读者 档案 实体 包括 编号 、 姓 名 、 性 别 、 条 形 码 、 职 业 、 出 生日 期 、 有 效 证 件 、 证 件 号 
| 码 、 电 话 、 电 子 邮 件 、 登 记 日 期 、 操 作 员 、 类 型 和 备注 等 属性 。 读 者 档案 实体 的 E-R 图 如 
| 图 4.3 所 示 。 


图 4.3 读者 档案 实体 E-R 图 
3. 借阅 档案 实体 
| 借阅 档案 实体 包括 编号 、 读 者 编号 、 图 书 编号 、 借 书 时 间 、 应 还 时 间 、 操 作 员 和 是 否 
| 归还 等 属性 。 借 阅 档案 实体 的 E-R 图 如 图 4.4 所 示 。 


图 44 借阅 档案 实体 E-R 图 
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4. 归还 档案 实体 


归还 档案 实体 包括 编号 、 读 者 编号 、 图 书 编号 、 归 还 时 间 和 操作 员 等 属性 。 归 还 档案 ， 


实体 的 E-R 图 如 图 4.5 所 示 。 


图 书 编号 
读者 编号 


图 4.5 归还 档案 实体 E-R 图 
4.3 系统 数据 表 设 计 


结合 实际 情况 及 对 用 户 需 求 的 分 析 ， 学 校 图 书馆 管理 系统 db_library 数据 库 主 要 包含 
10 个 数据 表 ， 如 表 4.1 所 示 。 
表 4.1 学 校 图 书馆 管理 系统 数据 表 


表 名 说 了 明 
tb_bookcase 图 书 书架 信息 表 
tb_bookinfo 图 书信 息 表 
tb_borrow 
tb_libra 
tb manager 
tb_parameter 
tb publishing 出 版 社 信 息 表 
tb_purview 权限 信息 表 
tb _reader 读者 信息 表 
tb readertype 读者 类 型 信息 表 


4.3.1 图 书信 息 表 


图 书信 息 表 主要 用 于 存储 图 书 的 基础 信息 。 该 数据 表 的 结构 如 表 4.2 所 示 。 
表 4.2 图 书信 息 表 结构 


图 书 条 形 码 


barcode 


bookname | varchar(70) | 图 书 名 称 
typeid | Int(10) | 图 书 类 型 
author | varchar(30) | 图 书 作 者 
translator | varchar(30) | 图 书 译 者 
ISBN varchar(20) 图 书 ISBN 
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多 %、 
SI 

字 段 名 数据 类 型 额 ” 外 说 明 

Trice foat(8，2) 图 书 定价 

page int(10) 图 书页 码 
bookcase int(10) 图 书 书架 
storage int(10) 图 书库 存 
inTime date 入 库 时 间 
operator varchar(30) 操作 员 
del tinyint(1 是 否 删除 
td int(11 auto increment 自动 编号 ID 


4.3.2 图书 借阅 信息 表 
图 书 借阅 信息 表 主 要 用 于 存储 图 书 的 借阅 信息 。 该 数据 表 的 结构 如 表 4.3 所 示 。 


borrowTime 
backTime 
operator 
ifback 


表 4.3 图 书 借阅 信息 表 


数据 类 型 
| ma | | 


int(10) 


4.3.3 读者 信息 表 


读者 信息 表 主 要 用 于 存储 读者 的 基础 信息 。 


表 4.4 读者 信息 表 


说 了 明 
自动 编号 ID 
读者 ID 编号 
图 书 ID 编号 
图 书 借阅 时 间 
图 书 归 还 时 间 
操作 员 
是 否 归 还 


该 数据 表 的 结构 如 表 4.4 所 示 。 


字 段 名 数 据 类 型 额外 说 了 明 
id int(10 auto_increment 自动 编号 ID 
name Varchar(20 读者 姓名 
sex varchar(4) 性 别 
barcode varchar(30) 读者 条 形 码 
vocation varchar(50) 读者 职业 
birthday date 出 生日 期 
papeType varchar(10) 读者 证 件 
papeNO Varchar(20 证 件 号 码 
tel varchar(20, 读者 电话 
email varchar(100) E-mail 地 址 
createDate date 办 卡 时 间 
operator varchar(30) 操作 员 
remark mediumtext 备注 
typeid int(11) 读者 类 型 


I 


第 5 章 系统 设计 


5.1 系统 实现 关系 图 
学 校 图 书馆 管理 系统 的 流程 图 如 图 5.1 所 示 。 


图 书 借阅 图 书 续 借 图 书 归还 


管理 员 管理 图 书 档案 信息 


| 一 一 | 管理 读者 档案 信息 图 书 借阅 档案 


1 


读者 档案 
下 
一 一 | 获取 读者 信息 


根据 读者 信息 获 
取 借阅 图 书信 息 


归还 相关 图 书 


图 书 归还 档案 


图 5.1 学 校 图 书馆 管理 系统 流程 图 


5.2 系统 功能 模块 设计 


5.2.1 系统 的 功能 模块 | 
经 实际 考察 、 分 析 ， 基 于 图 书馆 发 展 需求 ， 现 将 图 书馆 管理 系统 按照 功能 划分 为 管理 
员 、 图 书 档案 管理 和 图 书 借 还 等 功能 模块 。 其 中 ， 管 理 员 模 块 主要 用 于 实现 管理 员 登 录 、 | 
管理 员 添 加 、 设置 管理 员 、 删除 管理 员 等 过 程 ; 图 书 档案 管理 模块 主要 实现 图 书信 息 添加 、 | 
图 书信 息 修改 、 删 除 图 书信 息 等 过 程 ， 图 书 借 还 模块 主要 用 于 实现 图 书 的 借阅 、 续 借 、 归 | 
还 和 借阅 查询 等 功能 。 | 
5.2.2 系统 功能 模块 特点 | 
整个 图 书馆 管理 系统 不 但 可 以 按照 整体 需求 实现 各 种 功能 ， 同 时 也 可 以 帮助 图 书馆 管 | 
理 人 员 安全 、 稳 定 、 高 效 地 实现 管理 体制 。 其 中 ， 管 理 员 模 块 采用 权限 判断 机 制 来 实现 登 | 
录 过 程 ， 图 书 管理 模块 具有 快速 查询 、 易 于 维护 、 管 理 ， 方 便 查看 等 功能 特点 ， 图 书 借 还 | 
模块 可 以 更 改 用 户 的 图 书 借阅 状态 ， 以 此 来 实现 图 书 借阅 系统 的 完整 性 。 | 


“393。 


人 Pp 项 目 入 侧 乞 析 


第 6 章 系统 功能 实现 
6.1.1 系统 登录 


| 系统 登录 是 进入 学 校 图 书馆 管理 系统 的 入 口 ， 主 要 用 于 验证 管理 员 的 身份 。 运 行 本 系 
| 统 ， 首 先进 入 的 是 系统 登录 页 面 ， 在 该 页 面 中 ， 系 统管 理 员 可 以 通过 输入 正确 的 管理 员 名 
| 称 和 密码 登录 到 系统 首页 ， 当 用 户 没有 输入 管理 员 名 称 或 密码 时 ， 系 统 会 通过 JavaScript 
| 进行 判断 ， 并 给 予 信息 提示 。 系 统 登 录 页 面 的 运行 结果 如 图 6.1 所 示 。 


CR 加 书 谊 生理 系统 
| 


管理 员 宇 码 | 四邻 多 全 全 全 


图 6.1 系统 登录 页 面 的 运行 结果 
| 系统 登录 页 面 主要 用 于 收集 管理 员 的 输入 信息 及 通过 自 定义 的 JavaScript 函数 验证 输 
| 入 信息 是 否 为 空 。 该 页 面 中 所 涉及 的 表单 元 素 如 表 6.1 所 示 。 
| 表 6.1 系统 登录 页 面 所 涉及 的 表单 元 素 


| 
| password jsie | 

submit i value=" 确 定 " onclick="return check(form1)" “确定 ”按钮 

submit3 | reset Value=" 重 置 " “ 重 置 ”按钮 

submit2 button Value=" 关 闭 " onClick="window.closeQO:" 


6.1.2 ”查看 管理 员 列 表 


管理 员 登 录 后 ， 单 击 “ 系 统 设置 ”/“ 管 理 员 设置 ” 超 链接 ， 可 进入 查看 管理 员 列表 页 
| 面 。 在 该 页 面 中 , 将 以 表格 的 形式 显示 全 部 管理 员 及 其 权限 信息 ,并 提供 添加 管理 员 信息 、 
| 删除 管理 员 信 息 和 设置 管理 员 权 限 的 超 链接 。 查 看 管理 员 列 表 页 面 的 运行 结果 如 图 6.2 
| 所 示 。 


前 全 和 :入 六 于 >》 管理 该 


ER 


a 


图 62 查看 管理 员 列表 页 面 的 运行 结果 

6.1.3 添加 及 删除 管理 员 

管理 员 登 录 后 ， 单 击 “ 系 统 设置 ”/“ 管 理 员 设置 ” 超 链接 ， 可 进入 查看 管理 员 列 表 页 
面 ， 在 该 页 面 中 单 击 “ 添 加 管理 员 信息 ” 超 链 接 ， 可 打开 添加 管理 员 信息 页 面 。 添 加 管理 
员 信 息 页 面 的 运行 结果 如 图 6.3 所 示 。 


习 http://127.0.0.1- 添加 管理 员 入 种 大 ls:| | 


:图 有 受到 | 
: ®@o00089 


! 

! 

| 

Ea 
有 | 


图 63 添加 管理 员 信 息 页 面 的 运行 结果 
在 查看 管理 员 列表 页 面 ， 单 击 指定 管理 员 信息 后 面 的 “删除 ” 超 链接 ， 可 将 该 管理 员 | 
及 其 权限 信息 删除 。 
6.1.4 设置 管理 员 权限 


在 查看 管理 员 列 表 页 面 单 击 指定 管理 员 后 面 的 “权限 设置 ” 超 链接 ， 即 可 进入 权限 设 
置 页 面 ， 设 置 该 管理 员 的 操作 权限 。 权 限 设置 页 面 的 运行 结果 如 图 6.4 所 示 。 


独 http://127.0.0.1/mr/schoolboo neil | 


图 6.4 权限 设置 页 面 的 运行 结果 


权限 设置 页 面 中 所 涉及 的 表单 元 素 如 表 6.2 所 示 。 
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表 6.2 权限 设置 页 面 所 涉及 的 表单 元 素 


名 称 重要 属性 含义 
forml method="post" action="manager modifyok php" 表单 
id value="<?php echo $info[id]:?>" 管理 员 编号 
name text value="<?php echo $info[name]:?>" 管理 员 名 称 
sysset checkbox <?php if($info[sysset]=—1){ echo("checked"):}?> 系统 设置 
Teaderset checkbox <?php Sinfolreaderse = ){ echo("checke: 一 }?> 读者 管理 
checkbox 图 书 管理 


| checkbox | 


checkbox 


borrowback 


submit class="btn grey" 


“保存 ”按钮 


Submit 
button 


6.2 图书 档案 管理 模块 设计 


Submit2 Value=" 关 闭 " onClick="window.clos 


| 图 书 档案 管理 模块 主要 包括 查看 图 书信 息 列 表 、 添 加 图 书信 息 、 
| 图书 信息 和 查看 图 书 详细 信息 5 个 功能 。 


6.2.1 查看 图 书信 息 列 表 
管理 员 登 录 后 ， 单 击 “ 图 书 管 


表 页 面 ， 在 该 页 面 中 将 -di 息 列 表 ， 
链接 。 查 看 图 书信 息 列表 页 面 的 运行 结果 如 图 6.5 所 示 。 


知 源 国 书 谊 管理 系统 


当前 位 置 : 图 书 管理 》 图书 档案 管理 


“关闭 ”按钮 


修改 图 书信 息 、 删 除 


1”/“ 图 书 档案 管理 ” 超 链 接 ， 可 进入 查看 图 书信 息 列 
同时 提供 添加 、 删 除 和 修改 图 书信 息 的 超 


名 HH 碍 图 书 名 称 图 # 交 型 出 上 入 i 
1234s8799。。 PE 此 据 计 系 扩 开发 完全 手册 雪 所 技术 人 Rj 电 出 新 社 。 PE 书 可 从 员 只 
123454321 宝 向 系列 人 民 电 出 新 社 。 PE 书 名 从 下 。 员 了 
oresta2l 信息 科学 技术 。。 人 民间 电 出 版 社 。 Pa 书架 个 
arerllslstlol Wis 计算 机 程序 设 计 。。 人 民间 电 出 版 社 。 ve 从 汉 

图 6.5 查看 图 书信 息 列表 的 运行 结果 


另外 ， 图 书馆 管理 员 可 以 通过 单 击 “ 删 除 ” 列 下 的 “删除 ” 超 链接 来 实现 指定 图 书 的 


删除 。 


6.2.2 添加 图 书信 息 


在 查看 图 书信 息 列 表 页 面 中 单 击 “ 添 加 图 书信 息 ” 超 链接 , 可 进入 添加 图 书信 息 页 面 。 


添加 图 书信 息 页 面 的 运行 结果 如 图 6.6 所 示 。 
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图 6.6 添加 图 书信 息 页 面 的 运行 结果 


添加 图 书信 息 页 面 主要 用 于 收集 输入 的 图 书信 息 以 及 通过 自 定义 的 JavaScript 函数 验 
证 输入 信息 是 否 合法 。 该 页 面 所 涉及 的 重要 表单 元 素 如 表 6.3 所 示 。 | 


名 称 


forml 


typeid 


isbn 


bookcaseid 


表 6.3 
元 素 类 型 


select 


select 


添加 图 书信 息 页 面 所 涉及 的 重要 表单 元 素 


重要 属性 
method="post" action="book_ok.php" 
<?php include("Conn/conn.php"); 
$sql=mysql query("select * from tb_booktype"); 
S$info=mysql_fetch_array($sq)); 
dof 
?> 
<option value="<?php echo $info[id]:;?>"> 
<?php echo $info[typename]:?></option> 
<?php }while($info=mysql_fetch_array($sqD):2> 
<2php 
$sql2=mysql query("select * from tb_publishing"); 
$info2=mysql_fetch_array($sql2); 
dof 
?> 
<option value="<?php echo $info2[ISBN]:?>"> 
<2php echo $info2[pubname]:?></option> 
<?php }while($info2=mysql_fetch_array($sql2)):2> 
<?php 
$sql3=mysql query("select * from tb_bookcase"); 
$info3=mysql_fetch_array($sql3); 
dof 
?> 
<option value="<?php echo $info3[id];?>"> 
<2php echo $info3[name]:?></option> 
<?php }while($info3=mysql fetch array($sql3));?> 


图 书 类 型 


出 版 社 


书架 名 称 


Operator 
Submit 


form 


hidden 


value="<?php echo $info3[name]:?>" 
‘onClick="return check(form1)" 


操作 员 
“保存 ” 按 负 


Submit2 


Submit 
button 


onClick="history.backO:" 
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“返回 ”按钮 
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6.2.3 ”修改 图 书信 息 


| 在 查看 图 书 列表 页 面 ， 单 击 想 要 修改 的 图 书信 息 后 面 的 “修改 ” 超 链接 ， 可 进入 修改 
| 图 书信 息 页 面 。 修 改 图 书信 息 页 面 的 运行 结果 如 图 6.7 所 示 。 


图 6.7 修改 图 书信 息 页 面 的 运行 结果 


6.3 图 书 借 还 模块 设计 


| 图 书 借 还 模块 主要 包括 图 书 借阅 、 图 书 续 借 、 图 书 归 还 、 图 书 档案 查询 、 图 书 借阅 查 
询 和 借阅 到 期 提醒 6 个 功能 。 在 图 书 借阅 模块 中 的 用 户 只 有 操作 员 一 种 身份 ， 通 过 该 身份 
| 可 以 进行 图 书 借 还 等 相关 操作 。 图 书 借 还 模块 的 用 例 图 如 图 6.8 所 示 。 


| oe 
= 
Ea 


图 6.8 图书 借 还 模块 的 用 例 图 


6.3.1 图 书 借阅 


| 管理 员 登 录 后 ， 单 击 “ 图 书 借 还 ”/“ 图 书 借阅 ” 超 链接 ， 可 进入 图 书 借阅 页 面 ， 在 该 
| 页 面 中 的 “读者 条 形 码 ”文本 框 中 输入 读者 的 条 形 码 (如 1234561789) 后 ， 单 击 “ 确 定 ” 
| 按钮 ， 系 统 会 自动 检索 出 该 读者 的 基本 信息 和 未 归还 的 借阅 图 书信 息 。 如 果 检 索 到 对 应 的 
| 读者 信息 ,将 其 显示 在 页 面 中 ， 此 时 输入 图 书 的 条 形 码 或 图 书 名 称 后 ， 单 击 “ 确 定 ”按钮 ， 
| 可 借阅 指定 的 图 书 ， 运 行 结果 如 图 6.9 所 示 。 
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图 6.9 图 书 借阅 页 面 的 运行 结果 


图 书 借阅 页 面 总 体 上 可 以 分 为 两 部 分 : 一 部 分 用 于 查询 并 显示 读者 信息 ; 另 一 部 分 用 
于 显示 和 添加 读者 的 借阅 信息 .图 书 借阅 页 面 在 Dreamweaver 中 的 设计 效果 如 图 6.10 所 示 。 


证 才 关 浊 FSiO Si SEE 江上 弓 : SN neyy RAT 河 借 站 是 WIN ee Jar 用 


图 6.10 图 书 借阅 页 面 的 设计 效果 

在 进行 图 书 借阅 时 ， 系 统 要 求 每 个 读者 只 能 同时 借阅 一 定数 量 的 图 书 ， 并 且 该 数量 由 | 

读者 类 型 表 tb readerType 中 的 可 借 数量 number 决 定 ,所 以 在 此 编写 了 自 定义 的 checkbook0 

函数 ， 用 于 判断 当前 选择 的 读者 是 否 还 可 以 借阅 新 的 图 书 ， 同 时 该 函数 还 具有 判断 输入 读 
者 条 形 码 或 图 书 名 称 文本 框 是 否 为 空 的 功能 。 


6.3.2 ”图 书 续 借 


管理 员 登 录 后 ， 单 击 “ 图 书 借 还 ”/“ 图 书 续 借 ” 超 链接 ， 可 进入 图 书 续 借 页 面 。 在 该 
页 面 中 的 “读者 条 形 码 ”文本 框 中 输入 读者 的 条 形 码 (如 1234561789) 后 ， 单 击 “ 确 定 ” | 
按钮 ， 系 统 会 自动 检索 出 该 读者 的 基本 信息 和 未 归还 的 借阅 图 书信 息 。 如 果 检 索 到 对 应 的 
读者 信息 ， 则 将 其 显示 在 页 面 中 ， 此 时 单 击 “ 续 借 ” 超 链接 ， 即 可 续 借 指定 图 书 〈 即 将 该 | 
图 书 的 归还 时 间 加 上 该 书 的 可 借 天 数 30 天 计算 得 出 应 还 时 间 )。 图 书 续 借 页 面 的 运行 结果 | 
如 图 6.11 所 示 。 | 


图 6.11 “图 书 续 借 ”页 面 的 运行 结果 
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| 图 书 续 借 页 面 的 设计 方法 同 图 书 借阅 页 面 类 似 ， 所 不 同 的 是 ， 在 图 书 续 借 页 面 中 没有 
| 添加 借阅 图 书 的 功能 ， 而 是 添加 了 “ 续 借 ” 超 链接 。 图 书 续 借 页 面 在 Dreamweaver 中 的 设 
| 计 效 果 如 图 6.12 所 示 。 


图 6.12 “图 书 续 借 ”页 面 的 设计 效果 


| 633 图 书 归还 


| 管理 员 登 录 后 ， 单 击 “ 图 书 借 还 ”/“ 图 书 归 还 ” 超 链 接 ， 可 进入 图 书 归 还 页 面 。 在 该 
页 面 中 的 “读者 条 形 码 ”文本 框 中 输入 读者 的 条 形 码 (如 1234561789) 后 ， 单 击 “ 确 定 ” 
按钮 ， 系 统 会 自动 检索 出 该 读者 的 基本 信息 和 未 归还 的 借阅 图 书信 息 。 如 果 检 索 到 对 应 的 
| 读者 信息 ， 则 将 其 输出 到 浏览 器 ， 此 时 单 击 “ 归 还 ” 超 链接 ， 即 可 将 指定 图 书 归 还 。 图 书 
归还 页 面 的 运行 结果 如 图 6.13 所 示 。 


图 6.13 “图 书 归 还 ”页 面 的 运行 结果 
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第 7 章 结 论 


本 设计 以 PHP 为 开发 基础 ， 结 合 CSS、JavaScript 等 主流 技术 实现 图 书馆 管理 系统 。 
着 重 对 图 书馆 管理 体制 的 研究 , 本 设计 围绕 主流 Web 开发 应 用 技术 , 结合 动态 网 站 开发 特 


锚 


点 及 需求 ， 根 据 系统 运行 环境 、 设 计 系统 软件 对 图 书馆 管理 系统 的 研究 进行 讲解 。 本 次 设 | 
计 中 的 数据 库 采 用 MySQL， 选 用 该 数据 库 既 可 以 提高 系统 的 安全 性 与 稳定 性 ， 同 时 也 极 | 


大 地 降低 了 开发 成 本 。 另 外 ， 程 序 的 运行 采用 AppServ 集成 环境 ， 也 保证 了 软件 之 间 的 协 | 


同 作用 。 利 用 PHP 开源 性 与 易 开 发 性 等 特点 开发 程序 , 给 整个 过 程 带 来 了 很 大 方便 , 但 本 
系统 只 能 满足 绝 大 多 数 功能 需求 ， 对 于 各 个 图 书馆 的 实际 情况 ， 仍 需要 根据 个 体 因素 进 一 
步 对 程序 进行 调整 。 该 图 书馆 管理 系统 仍 有 待 于 完善 。 
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附录 A ” 主 程序 


<?php 
include ("check login.php"); 
include("conn/conn.php"); 
> 
<html> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<head> 
<title> 学 校 图 书馆 管理 系统 </title> 
<link href="CSS/style.css" rel="stylesheet"> 
</head> 
<table width="776" border="0" align="center"” cellpadding="0" cellspacing="0" class= 
"tableBorder"> 
<tr> 
<td> 
<?php include("navigation.php"); ?> 
</td> 
</tr> 
<td bgcolor="#FFFFFF"> 
<table width="100%" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td valign="top" bgcolor="#FFFFFF"> 
<table align="center" cellpadding="0" cellspacing="0" bgcolor="#FFFFFF" class="tableBorder_ 


gray'> 
<tr> 
<td align="center" valign="top" style="padding:Spx:"> 
<table width="738" border="0" cellpadding="0" cellspacing="0"> 
<tr> 
<td height="148" valign="top"><table width="738" border="0" cellspacing="0" cellpadding 
0"> 
<tr> 
<td width="753" height="44" background="Images/main_ booksort.gif'">&nbsp:</td> 
</tr> 
<tr> 


<td height="72" valign="top" background="Images/main booksort 1.gif'> 
<table cellspacing="0" bordercolor="#FFFFFF" bordercolordark="#D2E3E6" bordercolorlight 
="#FFFFFF"> 
<tr align="center"> 
<td width="4%" height="25"> 排 名 </td> 
<td width="10%"> 图 书 条 形 码 </td> 
<td width="22%"> 图 书 名称 </td> 
<td width="11%"> 图 书 类 型 </td> 
<td width="9%"> 书 架 </td> 
<td width="13%"> 出 版 社 </td> 
<td width="15%"> 作 者 </td> 
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<td width="8%"> 定 价 (元 )</td> 
<td width="8%"> 借 阅 次 数 </td> 


</t> 
<?php 
$sql=mysql_query("select * from (select bookid, count(bookid) as degree from tb _borrow group by 
bookid) as 


borr join (select b.*, c.name as bookcasename, p.pubname, t.typename from tb_bookinfo b left join 
tb_bookcase ¢ on b.bookcase=c.id join tb_publishing p on b.ISBN=p.ISBN join tb_booktype t on 
b.typeid=t.id | 
where b.del=0) as book on bor.bookid=book.id order by borr.degree desc limit 10"); 
// 提 交 数 据 库 查询 命令 
S$info=mysql_ fetch_ array($sq)):; // 遍 历数 据 库 
$i=l; 
dof 
> 
<tr> 
<td height="25" align="center"><?php echo $1;7?></td> 
<td style="padding: 5px:;">&nbsp;<?php echo $info[barcode]:?></td> 
<td style="padding:5px;"><?php echo $info[bookname];?></td> 
<td style="padding:5px:;"><?php echo $info[typename]:?></td> 
<td align="center">&nbsp;<?php echo $infofbookcasename]:?></td> 
<td align="center">&nbsp:;<?php echo $info[pubname]:?></td> 
<td align="center"><?php echo $info[author];?></td> 
<td align="center"><?php echo $info[price]:?></td> 
<td align="center"><?php echo $info[degree]:2></td> 
</tr> 
<2php 
$i=$i+1; 
}while($info=mysql fetch_array($sql)); 
> 
</table></td> 
</tr> 
<tr> 
<td height="19" background="Images/main_ booksort 2.gif'>&nbsp:</td> 
</tr> 
</table> 
</td> 
</tr> 
</table> 
<p>&nbsp;</p></td> 
</t> 
</table></td> 
</tr> 
</table> 
<?php include("copyright.php"); ?></td> 
</tr> 
</table> 
</html> 
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附录 B 子 程 序 


<2php session_start():?> 
<html> 
<head> 
<link href="CSS/style.css" rel="stylesheet"> 
<script language="javascript"> 
function checkreader(form){ 
if(form.barcode.value—""){ 
alert(" 请 输入 读者 条 形 码 !:form .barcode.focusO:return: 
} 
form.submitO; 
} 
function checkbook(form){ 
if(form.barcode.value—""){ 
alert(" 请 输入 读者 条 形 码 !"):form .barcode.focusO:return: 
} 
if(form.inputkey.value—""){ 
alert(" 请 输入 查询 关键 字 !"):form inputkey .focusO:return; 
} 
if(form.number.value-form.borrowNumber.value<=0){ 
alert(" 您 不 能 再 借阅 其 他 图 书 了 !"):return; 


form.submit():; 
) 


</script> 
</head> 
<body> 
<?php include("navigation.php"):;?> 
<table width="776" border="0" cellspacing="0" cellpadding="0" align="center"> 
<tr> 
<td valign="top" bgcolor="#FFFFFF"><table width="100%" height="509" 


align="center" cellpadding="0" cellspacing="0" bgcolor="#FFFFFF" class="tableBorder gray"> 


<tr> 


border="0" 


<td align="left" valign="top" style="padding:Spx:"> &nbsp:; <span class="word_orange">&nbsp; 


当前 位 置 : 图 书 借 还 &gt 图 书 借阅 &gt&gt&gt </span> <table width="100%" 
cellpadding="0" cellspacing="0"> 


<?php 
include("conn/conn.php"); 


border="0" 


$sql=mysql_query("select r.*,tname as typename,tnumber from tb reader T left join 


tb_readerType t on r.typeid=t.id where r.barcode=".$ POST[barcode].""); 


S$info=mysql fetch_array($sql); 


?> 

<!-- 中 间 省 略 部 分 代码 --> 
</tr> 
<?php 
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S$readerid=$info[id]; 

$sqll=mysql_query("select 
I.*,borr.borrowTime,borr.backTime,book.bookname,book.price,pub.pubname,bc.name as bookcase ”from 
tb borrow as bor join tb bookinfo as book on book.id=borr.bookid join tb publishing as pub on 
book.ISBN=pub.ISBN join tb_bookcase as bc on book.bookcase=bc.id join tb_reader as r on borr.readerid=r.id 
where borr.readerid='$readerid' and borr.ifback=0"); 

//$sql=mysql_ query("select tdays from tb_bookinfo b left join tb_booktype t on b.typeid=t.id where 
b.barcode=".$_ POST[barcode].""):; 

S$infol=mysql fetch array($sqll); 

$borrowNumber=mysql_num rows($sqll): 

/获取 结果 集中 行 的 数目 

dof 

?> 

<tr> 

<!-- 中 间 省 略 部 分 代码 --> 

<2php 

}while($infol=mysql fetch array($sql1)); 

> 

<input name="borowNumber" type="hidden" id="borrowNumber" value="<?php echo 

$borrowNumber; ?>"> 


</table></td> 
</tr> 
</table></td> 
</tr> 
<tr> 
<td height="19" background="Images/main booksort 2.gif'>&nbsp;</td> 
</tr> 
</form> 
<2php 
if($_POST["inputkey"]!=""){ // 判 断 是 否 获取 提交 键 
$f=$_POST["f"]; // 获 取 传 递 值 


S$inputkey=trim($_POST["inputkey"]); 
$barcode=$_POST["barcode"]; 
S$readerid=$_POST["readerid"]: 
$borrowTime=date(Y-m-d): 
// 归 还 图 书 日 期 为 当前 期 日 期 +30 天 期 限 
S$backTime=date("Y-m-d",(time(}+3600*24*30)): 
$query=mysql_query("select * from tb_bookinfo where $='$inputkey""); 
/检索 图 书信 息 是 否 存在 
$result=mysql_fetch_array($query); 
if($result=—=false){ 
echo "<script language='javascript>alert( 该 图 书 不 存在 ! )windowlocationhre 伟 
‘bookBorrow.php?barcode=$barcode':</script>"; 
} 
else{ 
$queryl=mysql_query("select 
I.*,borr.borrowTime,borr.backTime,book.bookname,book.price,pub.pubname,bc.name as bookcase friom 
tb_borrow as borr join tb_reader as T on borr.readerid=r.id join tb_bookinfo as book on book.id=borrbookid join 
tb publishing as pub on bookISBN=pub.ISBN  joim tb bookcase as bc on book.bookcase=bc.id where 
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| SS 
| borr.bookid=$result[id] and borr.readerid=$readerid and ifback=0"): // 检 索 该 读者 所 借阅 的 
| 图 书 是 否 与 再 借 图 书 重 复 
| Sresultl=mysql fetch_array($query]): 
| 这 $resultl 一 tme){ /如 果 借 阅 的 图 书 已 被 该 读者 借阅 ， 那 么 提示 不 能 
一 一 | echo "<script language='javascript>alert(' 该 图 书 已 经 借阅 ! ):windowlocation hrefbook 
Borrow.php?barcode=$barcode';</script>"; 
} 
else{ // 否 则 ， 完 成 图 书 借阅 操作 


$bookid=$result[id]; 
| mysql query("insert into tb_borrow(readerid,bookid,borrowTime,backTime,operator,ifback)values 
('$readerid','$bookid','$borrowTime','$backTime','$_SESSION[admin_name]',0)"); 
| echo "<script language='javascript'>alert( 图 书 借 阅 操作 成 功 ! ");window.location.href='book 
| Borrow.php?barcode=$barcode':</script>"; 
| } 
| } 
} 
| ?> 
| </table></td> 

</tr> 
‘</table> 

<?php include("copyright.php"):?></td> 
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XX 师范 大 学 本 科 毕 业 论 文 (设计) 开题 报告 


基于 PHP 的 电子 商务 网 站 系统 设计 


信息 工程 学 院 专 业 计算 机 科学 与 技术 
XXX 指导 教师 XXX (职称 ) 


本 选 题 的 意义 及 在 国内 外 的 发 展 状况 : 

电子 商务 是 一 项 全 新 的 经 济 方式 ， 它 的 产生 和 发 展 必 将 对 世界 经 济 产生 重大 的 影 
响 。 电 子 商 务 正 在 深刻 地 改变 着 经 济 、 市 场 和 产业 结构 ; 改变 着 产品 、 服 务 及 其 流动 ; 
改变 着 消费 者 的 价值 和 行为 ， 改 变 着 就 业 和 劳动 力 市 场 。 对 一 个 企业 来 说 ， 电 子 商务 是 
-种 新 的 经 营 手段 。 随 着 网 络 和 电子 商务 的 发 展 ， 越 来 越 多 的 企业 开始 以 电子 商务 的 方 
式 实现 管理 和 营销 时 ， 便 形成 了 一 个 电子 商务 的 经 营 和 市 场 环境 ， 这 是 一 个 全 新 的 竞争 
激烈 的 国际 化 市 场 。 为 适应 这 种 新 的 经 营 环境 ， 应 对 来 自 全 球 竞争 者 的 挑战 ， 我 国 的 电 
子 商务 企业 和 开展 或 即将 开展 电子 商务 的 传统 企业 ， 除 要 选择 适合 自身 发 展 的 商业 模式 
外 ， 也 需要 建立 自己 的 电子 商务 网 站 系统 ， 以 提高 企业 的 竞争 力 。 

研究 内 容 : 

基于 PHP 的 电子 商务 网 站 系统 原理 设计 。 

基于 PHP 的 电子 商务 网 站 系统 程序 设计 。 

前 台 页 面 设计 和 软件 部 分 调试 。 

研究 方法 、 手 段 及 步骤 

系统 流程 设计 : 针对 本 设计 要 求 并 配合 查阅 网 上 资料 ， 设 计 整 个 实现 流程 。 

原理 图 绘制 : 应 用 绘图 软件 绘 出 原理 图 。 

前 台 页 面 设计 : 应 用 Dreamweaver 软件 ， 结 合 JavaScript 语言 设计 前 台 界 面 。 

后 台 程序 编写 : 根据 原理 图 要 求 编程 。 

前 台 页 面 和 后 台 程 序 的 联合 调试 : 测试 已 经 完成 的 程序 , 修正 逻辑 问题 及 语法 错误 。 

参考 文献 : 

[] 邹 天 思 ， 孙 鹏 . PHP 从 入 门 到 精通 [M]. 北京 : 清华 大 学 出 版 社 ，2008. 

[2] 潘 凯 华 ， 邹 天 思 . PHP 开发 实战 宝典 [M]. 北京 : 清华 大 学 出 版 社 ，2010. 

[3] 邹 天 思 ， 潘 凯 华 ， 刘 中 华 .PHP 网 络 编程 自学 手册 [M]. 北京 : 人 民 邮 电 出 版 社 ， 
2008. 

[4]( 美 ) Vasani. MySQL 完全 手册 [M]. 徐 小 青 ， 路 晓 村 等 译 . 北京 : 电子 工业 出 
版 社 ，2004 

[5] 潘 凯 华 等 . PHP 项 目 开发 案例 全 程 实录 [M]. 2 版 . 北京 : 清华 大 学 出 版 社 ，2011 
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附录 且 SS 


摘 要 


| 鲜 

随 着 互联 网 技术 的 迅猛 发 展 ， 在 市 场 经 济 下 企业 交易 越 来 越 趋向 于 多 元 化 ， 而 客观 经 
济 环 境 的 变化 ， 使 企业 在 开展 电子 商务 方面 势 在 必 行 。 电 子 商 务 不 仅仅 适用 于 大 企业 ， 对 
中 小 企业 也 非常 有 利 ， 更 是 为 中 小 企业 与 大 企业 的 竞争 提供 了 很 好 的 机 会 和 平台 。 中 小 企 | 
业 作为 各 国 经 济 的 基础 和 社会 经 济 中 最 为 活跃 的 因素 ， 成 为 社会 经 济 储蓄 发 展 和 繁荣 稳定 | 
的 重要 保障 。 与 此 同时 ， 电 子 商务 作为 新 经 济 时 代 下 的 产物 ， 已 经 成 为 众多 企业 关注 和 利 | 
用 的 焦点 。 发 展 电子 商务 将 是 中 小 企业 在 未 来 取得 长 足 发 展 的 必由之路 。 本 文 阐述 了 如 何 
利用 PHP 开发 电子 商务 网 站 ， 从 而 使 中 小 企业 发 展 电 子 商 务 , 在 激烈 的 市 场 竞争 中 立 于 不 
败 之 地 。 


关键 词 ， 电子 商务 中 小 企业 发 展 PHP 


wy 0 L_ 


日 
\ St 


, 人 Pitp 项 目 案 们 分 析 
不 祝 


Abstract 


With the rapid development of intermet, business transactions are increasingly in favor of 
diversification. What’s more, the changes from objective economic environment stimulate 
corporations to promote e-business inevitably. It ls not only applicable for large organizations, 
but also for small and medium-sized enterprises, which provides both of them with a fine 
platform in competition. As the economic foundation of a nation and the most active element in 
social economy, SME(small and medium-sized enterprises) guarantee socio-economic savings 
development, prosperity and stability. In the meantime, generated in this new economic era, 
e-business has been wildly noted and exploited by numerous enterprises, which will definitely 
lead SME to the future success.This text introduced the process of e-commerce systems 
developing with PHP, in order to establish themselves in an unassailable position in this violent 
market competition. 


Keywords: E-commerce Small and midium-sized enterprises Development PHP 
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第 1 章 绪 论 


1.1 本 课题 的 开发 背景 及 意义 


1.1.1 设计 的 背景 


电子 商务 是 一 项 全 新 的 经 济 方式 ， 它 的 产生 和 发 展 必 将 对 世界 经 济 产生 重大 的 影响 。 | 
电子 商务 正在 深刻 地 改变 着 经 济 、 市 场 和 产业 结构 ， 改 变 着 产品 、 服 务 及 其 流动 ， 改 变 着 | 
消费 者 的 价值 和 行为 ， 并 改变 着 就 业 和 劳动 力 市 场 。 | 


1.1.2 开发 意义 


对 一 个 企业 来 说 ， 电 子 商 务 是 - -种 新 的 经 营 手段 。 随 着 网 络 和 电子 商务 的 发 展 ， 越 来 | 
越 多 的 企业 开始 以 电子 商务 的 方式 实现 管理 和 营销 时 ， 便 形成 了 一 个 电子 商务 的 经 营 和 市 | 
场 环境 ， 这 是 一 个 全 新 的 竞争 激烈 的 国际 化 市 场 。 为 适应 这 种 新 的 经 营 环境 ， 应 对 来 自 全 | 
ne id > 业 和 开展 或 即将 开展 电子 商务 的 传统 企业 ， 除 要 选择 | 

合 自身 发 展 的 商业 模式 外 ， 也 需要 建立 自己 的 电子 商务 网 站 系统 ， 并 通过 互联 网 宣传 ， | 
Was 


1.2 课题 研究 内 容 


本 设计 主要 应 用 PHP 编程 、Web 开发 以 及 MySQL 数据 库 连 接 等 相关 知识 ,利用 动态 | 
网 页 开发 技术 ， 将 所 学 的 知识 用 于 实际 的 生活 中 ， 并 且 在 实际 的 生活 中 发 挥 其 主要 功能 并 | 
获得 效益 ， 本 设计 内 容 包括 以 下 功能 模块 。 | 
回 商品 展示 模块 :主要 包括 推荐 商品 展示 、 最 新 商品 展示 、 特 价 商品 展示 、 商 品 分 | 
类 展示 以 及 查看 商品 详细 信息 等 功能 | 
回 购物 车 模块 : 主要 包括 添加 商品 至 购物 车 、 查 看 购物 车 、 修 改 购物 车 中 商品 数量 、| 
移 除 购物 车 内 指定 商品 和 清空 购物 车 等 操作 。 | 
回 ”搜索 模块 : 主要 包括 简单 搜索 和 高 级 搜索 两 种 搜索 方式 。 
回 ”订单 管理 模块 : 主要 包括 查看 订单 、 执 行 订 单 、 打 印 订 单 和 查找 订单 等 操作 。 
回 ”商品 管理 模块 : 主要 包括 添加 商品 信息 、 修 改 商 品 信息 和 删除 商品 信息 等 操作 。 


1.3 设计 组 织 结构 


本 毕业 设计 的 主体 主要 分 为 6 大 部 分 。 | 

加 第 1 部 分 : 即 绪论 部 分 ， 主 要 介绍 毕业 设计 (论文) 的 开发 背景 和 意义 、 st 
容 、 组 织 结构 等 内 容 。 

回 第 2 部 分 : 主要 全 组 本 毕业 设计 中 所 用 到 的 开发 软 件 、 运 行 环境 以 及 开发 过 各 所 | 
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需要 的 结构 体系 等 要 素 。 

第 3 部 分 : 介绍 系统 的 可 行 性 分 析 以 及 功能 需求 等 内 容 。 

第 4 部分: 介绍 数据 库 的 基本 数据 表 结 构 设 计 。 

第 5 部 分 : 根据 需求 分 析 整 个 系统 的 构架 并 陈列 主要 功能 模块 。 
第 6 部 分 : 详细 讲解 各 功能 模块 的 实现 过 程 和 运行 结果 。 


网罗 网 网 
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第 2 章 开发 工具 及 相关 技术 


2.1 开发 工具 


2.1.1 Zend Studio 


Zend Studio 是 Zend Technologies 开发 的 PHP 语言 集成 开发 环境 (Integrated 
Development Environment，IDE)， 也 支持 HTML 和 JS 标签 ， 但 只 对 PHP 语言 提供 调试 支 | 
持 。 因 为 是 同一 个 公司 的 产品 ， 所 以 提供 的 Zend Framework 方面 的 支持 比 其 他 软件 好 。 | 
Zend Studio 5.5 系列 后 , 官方 推出 利用 Eclipse 平台 、 基 于 PDT 的 Zend Studio for Eclipse 6.0， | 
之 后 的 版 本 也 都 构建 于 Eclipse。 | 

Zend Studio 是 屡 获 大 奖 的 专业 PHP 集成 开发 环境 ， 具 备 功能 强大 的 专业 编辑 工具 和 | 
调试 工具 ,支持 PHP 语法 加 亮 显 示 、 语 法 自动 填充 、 书 签 、 语 法 自动 缩 排 和 代码 复制 等 功 | 
能 ， 内置 一 个 强大 的 PHP 代码 调试 工具 , 支持 本 地 和 远程 两 种 调试 模式 , 支持 多 种 高 级 调 | 
试 功能 。 | 

2.1.2 EclipsePHP Studio 


EclipsePHP Studio (简称 EPP ) 是 一 个 大 型 PHP 项 目 开发 编译 器 ， 基 于 Eclipse 底层 | 
开发 而 来 ， 并 且 集 成 了 JDK， 免 除了 安装 配置 的 麻烦 ， 一 次 安装 即 可 使 用 ， 无 需 配 置 。 此 | 
编译 器 为 PHP 编译 器 ， 辅 助 PHP 代码 的 开发 和 调试 ， 集 成 了 代码 高 亮 、 函 数 跟踪 和 时 时 | 
纠 错 等 功能 。 同 时 还 增加 了 协作 开发 版 本 服务 器 功能 SVN 和 CVS。 内 购 浏 览 器 可 以 在 调 | 
试 简单 代码 时 浏览 。 不 仅 支 持 PHP， 也 支持 其 他 网 络 语言 ， 如 HIML、XHTML、XML、 | 
CSS、JavaScript、Java、Perl、Python 等 。 


2.1.3 PHP Designer 


PHP 是 一 种 能 嵌入 到 其 他 网 络 编程 语言 的 技术 。PHP Designer 不 仅 支持 PHP, 也 支持 | 
其 他 网 络 语言 ， 如 HTML、XHIM、 XML、CSS、JavaScript、VBScript、Java、C#、Perl | 
和 Python 等 。 | 
由 于 互联 网 上 具有 丰富 的 免费 资源 ， 越 来 越 多 的 人 热衷 于 对 PHP 的 学 习 ，MPS PHP | 
Designer 是 针对 PHP 网 页 的 编写 所 设计 的 程序 ， 它 内 建 一 系列 的 指令 码 、PHP4 原始 码 数 | 
据 库 、 语 法 高 亮度 显示 功能 、FTP 客户 端 等 ,无 论 是 PHP 网 页 设计 高 手 ， 还 是 刚 入 门 的 新 | 
手 ， 都 可 以 使 用 这 套 软件 来 帮助 开发 者 设计 网 页 程序 (SQL、HTML 亦 支 持 )。 | 

PHP Designer 7.0 支持 PHP 中 用 户 最 喜欢 的 框架 ， 也 支持 任何 流行 的 JavaScript 框架 ，| 
如 jQuery 的 全 雅虎 UI 库 、ExtS 原型 和 MooTools。 | 

最 新 版 PHP Designer 2008， 是 完整 的 集成 开发 环境 ， 无 论 对 于 PHP 初学 者 还 是 专业 | 
开发 人 员 ， 均 对 用 户 提高 自身 的 编程 技能 有 很 大 帮助 。 | 
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2.1.4 PHPEdit 


PHPEdit 是 一 款 Windows 下 优秀 的 PHP 脚本 IDE (集成 开发 环境 )。 该 软件 为 快速 、 
便捷 地 开发 PHP 脚本 提供 了 多 种 工具 ， 其 功能 包括 语法 关键 词 高 亮 ; 代码 提示 、 浏 览 ; 集 
成 PHP 调试 工具 ; 帮助 生成 器 ， 自 定义 快捷 方式 ;150 多 个 脚本 命令 ; 键盘 模板 ; 报告 生 
成 器 ; 快速 标记 ; 插件 等 。 

来 自 WaterProof Software 的 PHPEdit 感觉 像 是 应 用 于 PHP 的 Microsoft msdev 环境 。 


| PHPEdit 是 仅 用 于 Windows 的 IDE, 很 容易 设置 。 它 甚至 还 有 PHP 的 版 本 。 在 PHP、CSS 
| 和 HTML 的 代码 智能 方面 做 得 很 好 ， 但 是 却 不 提供 对 Javascript 代码 的 智能 支持 。 为 了 便 
| 于 部 署 ，PHPEdit 可 以 连接 到 CVS、Subversion 以 及 FTP 和 它 自己 专 有 的 ezDeployment 


系统 。 除 了 代码 智能 特性 ， 为 了 加 速 开 发 ， 这 款 IDE 有 一 个 极 好 的 代码 示例 整体 模板 库 ， 
用 户 可 以 向 库 里 添加 内 容 。 


2.2 ”运行 环境 


2.2.1 AppServ 集成 环境 


AppServ 是 PHP 网 页 架 站 工具 组 合 包 , 作者 将 一 些 网 络 上 免费 的 架 站 资源 重新 包装 成 
单一 的 安装 程序 ， 以 方便 初学 者 快速 完成 架 站 ，AppServ 所 包含 的 软件 有 Apache、Apache 
Monitor、PHP、MySQL、phpMyAdmin 等 。 如 果 用 户 的 本 地 机 器 没有 安装 过 php、mysql 
等 系统 ， 那 么 用 该 软件 可 以 让 用 户 迅 速 搭建 完整 的 PHP 运行 环境 。 

2.2.2 ”WAMP 集成 环境 


WAMP 是 多 个 词 的 缩写 , 即 Windows 下 的 Apache+Mysql+Perl/PHP/Python, 它 是 一 组 


| 常用 来 搭建 动态 网 站 或 者 服务 器 的 开源 软件 ， 这 些 软件 本 身 都 是 相互 独立 的 程序 ， 但 是 因 


为 这 些 程序 在 应 用 PHP 技术 开发 Web 程序 的 过 程 中 常 被 放 在 一 起 使 用 ， 拥 有 了 越 来 越 高 
的 兼容 度 ， 共 同 组 成 了 一 个 强大 的 Web 应 用 程序 平台 。 

随 着 开源 潮流 的 莲 勃 发 展 , 开放 源 代码 的 LAMP 已 经 与 2EE 和 .Net 商业 软件 形成 三 足 时 
立 之 势 ， 并 且 该 软件 开发 的 项 目 在 软件 方面 的 投资 成 本 较 低 ， 因 此 受到 整个 IT 界 的 关注 。 

LAMP 是 基于 Linux、Apache、MySQL 和 PHP (PHP 有 时 可 用 Per 或 Python 代替 ) 
的 开放 资源 网 络 开发 平台 ， 这 个 术语 来 自 欧 洲 ， 在 那里 ， 这 些 程序 常用 来 作为 一 种 标准 开 
发 环境 。 每 个 程序 在 所 有 权 里 都 符合 开放 源 代码 标准 : Linux 是 开放 系统 ，Apache 是 最 通 
用 的 网 络 服务 器 ， MySQL 是 带 有 基于 网 络 管理 附加 工具 的 关系 数据 库 ， PHP 是 流行 的 对 
象 脚本 语言 ， 它 包含 了 多 数 其 他 语言 的 优秀 特征 来 使 得 其 网 络 开发 更 加 有 效 。 开 发 者 在 
Windows 操作 系统 下 使 用 这 些 Linux 环境 里 的 工具 称 为 使 用 WAMP。 

2.2.3 XAMPP 集成 环境 


XAMPP (Apache+MySQL+PHP+Perl) 是 一 个 功能 强大 的 建 XAMPP 软件 站 集成 软件 

包 。 该 软件 包 原 来 的 名 字 是 LAMPP， 但 是 为 了 避免 引起 误解 ， 最 新 的 几 个 版 本 改名 为 

XAMPP。 它 可 以 在 Windows、Linux 和 Solaris 3 种 操作 系统 下 安装 使 用 ， 支 持 多 语言 ， 如 
“418 。 


英文 、 简 体 中 文 、 繁 体 中 文 、 韩 文 、 俄 文 、 日 文 等 。 | 
XAMPP 是 一 款 具 有 中 文 说 明 的 功能 全 面 的 集成 环境 ， 并 不 仅仅 针对 Windows， 而 是 | 
个 适用 于 Linux、Windows、Mac OS X 和 Solaris 的 易于 安装 的 Apache 发 行 版 。 软 件 包 | 
中 包含 Apache 服务 器 、MySQL、SQLite、PHP、Perl、FileZilla FTP Server、Tomcat 等 。 | 
默认 安装 开放 了 所 有 功能 ， 但 其 安全 性 有 问题 ， 需 要 进行 额外 的 安全 设 定 。 
总 的 来 说 ， 以 上 几 种 集成 环境 基本 上 都 可 以 满足 设计 配置 WAMP 环境 的 需要 ， 其 中 ， | 
XAMPP 和 AppServ 各 种 组 件 较 全 ， 但 文件 组 成 较 复 杂 ， 不 利于 初学 者 学 习 , 而 WAMP 具 | 
有 很 多 优点 ， 特 别 适 合 初 学 者 使 用 。 | 


2.3 ”相关 技术 


2.3.1 PHP 的 工作 原理 及 相关 技术 


PHP (Hyper Text Preprocessor) 是 一 种 多 平台 无 颖 运行 的 服务 器 端 嵌 入 式 脚本 语言 ， 
它 融 合 了 C、Java 和 Perl 等 编程 语言 ， 由 于 它 是 一 种 免费 的 软件 ， 具 有 自由 软件 的 性 质 ， | 
且 版 本 更 新 速度 快 、 移 植 速度 快 ， 具 有 丰富 的 函数 库 功能 ， 因 而 很 快 得 到 用 户 认 可 ， 特 别 | 
是 PHP 提供 加 密 函 数 库 ， 符 合 安全 性 较 高 的 电子 商务 网 站 的 要 求 ， 在 Apache 环境 下 构建 | 
的 PHP 网 站 已 经 成 为 当前 流行 的 Web 网 站 之 一 | 

PHP 能 够 作为 Apache Web 服务 器 的 模块 执行， 使 得 其 执行 效率 要 高 于 普通 的 CGI 程 
序 ， 而 且 能 比 CGI 或 者 Perl 更 快速 地 执行 动态 网 页 。 | 

使 用 者 如 果 创 建 了 一 个 PHP 应 用 程序 ， 实 际 上 相当 于 创建 了 一 个 PHP 脚本 文件 。 在 | 
服务 器 将 输出 信息 发 送 到 客户 端 之 前 ， 网 络 服务 器 会 率先 将 文件 中 的 PHP 语言 进行 加 工 处 | 
理 。 如 果 服 务 器 不 支持 PHP， 通 常情 况 下 ， 网 络 服务 器 会 直接 将 超 文本 文件 送 到 客户 的 浏 | 
览 器 上 以 表示 对 HTTP 的 要 求 作出 应 答 ; 如 果 服 务 器 支持 PHP， 则 在 服务 器 响应 一 个 对 | 
PHP 文件 的 请 求 时 ， 会 进行 如 下 处 理 : 首先 在 一 个 PHP 文件 内 ， 标 准 的 HTML 编码 会 被 | 
直接 送 到 浏览 器 上 , 而 内 风 PHP 程序 却 是 先 被 网 络 服务 器 解释 执行 。 如 果 是 标准 输出 , 输 | 
出 信息 也 将 作为 标准 的 HTML 而 被 送 至 浏览 

PHP 可 以 安装 在 UNIX/Linux 环境 下 ， 也 可 以 安装 在 Windows 环境 下 。 目 前 网 站 使 用 | 
最 多 的 ， 也 是 最 理想 的 便 是 PHP+MySQL+Apache 基于 UNIX/Linux 下 的 服务 器 策略 。 

2.3.2 JavaScript 语言 


JavaScript 是 一 种 解释 性 的 、 基 于 对 象 的 脚本 语言 (an interpreted, object-based scripting | 
language )。 | 
HTML 网 页 在 互动 性 方面 能 力 较 弱 ， 如 下 拉 菜 单 用 纯 HTML 网 页 无 法 实现 ， 又 如 验证 | 
HTML 表单 (Form) 提交 信息 的 有 效 性 时 ， 用 户 名 不 能 为 空 ， 密 码 不 能 少 于 4 位 ， 邮 政 编码 | 
只 能 是 数字 等 ， 用 纯 HTML 网 页 也 无 法 实现 。 要 实现 这 些 功 能 ， 就 需要 用 到 JavaScript。 | 
JavaScript 是 一 种 脚本 语言 ， 比 HTML 要 复杂 。 不 过 即便 先前 不 懂 编 程 ， 也 不 用 担心 ，| 
为 JavaScript 编写 的 程序 都 是 以 源 代码 的 形式 出 现 的 ， 也 就 是 说 在 一 个 网 页 里 看 到 一 段 | 
比较 好 的 JavaScript 代码 ， 恰 好 也 用 得 上 ， 就 可 以 直接 复制 ， 然 后 放 到 自己 的 网 页 中 去 。 | 
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正 因为 可 以 借鉴 、 参 考 优秀 网 页 的 代码 ， 所 以 让 JavaScript 本 身 也 变 得 非常 受 欢迎 ， 从 而 
被 广泛 应 用 。 原 来 不 懂 编 程 的 人 ， 多 参考 JavaScript 示例 代码 ， 也 能 很 快 上 手 。 

JavaScript 主要 是 基于 客户 端 运行 的 ， 用 户 单 击 带 有 JavaScript 的 网 页 ， 网 页 里 的 
JavaScript 就 传 到 浏览 器 ， 由 浏览 器 处 理 。 前 面 提 到 的 下 拉 菜 单 、 验 证 表单 有 效 性 等 大 量 
互动 性 功能 ， 都 是 在 客户 端 完成 的 ， 不 需要 和 Web Server 发 生 任何 数据 交换 ， 因 此 ， 不 会 
增加 Web Server 的 负担 。 

几乎 所 有 浏览 器 都 支持 JavaScript, 如 Intermet Explorer (IE)、 Firefox、 Netscape、 Mozilla 


| 和 Opera。 


2.3.3 CSS 概述 
CSS 样式 表 定 义 如 何 显示 HTML 元 素 ， 就 像 HTML 的 字体 标签 和 颜色 属性 起 的 作用 


那样 。 样 式 通常 保存 在 外 部 的 .CSS 文件 中 。 仅 编辑 一 个 简单 的 CSS 文档 ， 外 部 样式 表 就 
| 可 同时 改变 站 点 中 所 有 页 面 的 布局 和 外 观 。 


由 于 允许 同时 控制 多 重 页 面 的 样式 和 布局 ，CSS 可 以 称 得 上 Web 设计 领域 的 一 个 突 


| 破 。 作 为 网 站 开发 者 ， 能 够 为 每 个 HTML 元 素 定义 样式 , 并 将 其 应 用 于 所 希望 的 任意 多 个 
| 页面 中 。 如 需 进行 全 局 变换 ， 只 需 简单 地 改变 样式 ， 网 站 中 的 所 有 元 素 均 会 自动 地 更 新 。 


| 2.4 ”B/S 系统 结构 


B/S (BrowserServer) 结构 即 浏览 器 和 服务 器 结构 。 它 是 随 着 Intemet 技术 的 兴起 ， 


| 对 C/S 结构 的 一 种 变化 或 者 改进 的 结构 。 在 这 种 结构 下 , 用 户 工作 界面 是 通过 WWW 浏览 
| 器 来 实现 的 ， 极 少 部 分 事务 逻辑 在 前 端 (Browser) 实现 ， 但 是 主要 事务 逻辑 在 服务 器 端 


(Server) 实现 ， 形 成 所 谓 三 层 3-tier 结构 。 这 样 就 大 大 简化 了 客户 端 计算 机 载荷 ， 减 轻 了 


| 系统 维护 与 升级 的 成 本 和 工作 量 ， 降 低 了 用 户 的 总 体 成 本 CTCO)。 以 目前 的 技术 看 ， 局 
| 域 网 建立 B/S 结构 的 网 络 应 用 ,并 通过 IntemevIntranet 模式 下 数据 库 应 用 , 相对 易于 把 握 ， 
| 成 本 也 是 较 低 的 。 它 是 一 次 性 到 位 的 开发 ， 能 实现 不 同 的 人 员 从 不 同 的 地 点 以 不 同 的 接 入 
| 方式 (如 LAN、WAN、Intemet/Intranet 等 ) 访问 和 操作 共同 的 数据 库 。 它 能 有 效 地 保护 数 


据 平 台 和 管理 访问 权限 ， 服 务 器 数据 库 也 很 安全 。 特 别 是 在 Java 这 样 的 跨 平 台 语言 出 现 
之 后 ，B/S 结构 管理 软件 更 是 方便 、 速 度 快 、 效 果 好 。 其 系统 结构 如 图 2.1 所 示 。 


| Eo a 


应 用 服务 器 图 弄 用 户 界面 数据 库 服务 器 


Intranet 


图 2.1 B/S 系统 结构 
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一 
随 着 mtemet 和 WWW 的 流行 , 以 往 的 主机 /终端 和 C/s 都 无 法 满足 当前 的 全 球 网 络 开 | 
放 、 互 联 、 信 息 随处 可 见 和 信息 共享 的 新 要 求 ， 于 是 就 出 现 了 B/S 型 模式 ， 即 浏览 器 /服务 | 
器 结构 。B/S 结构 最 大 的 特点 是 ， 用 户 可 以 通过 WWW 浏览 器 去 访问 Intemet 上 的 文本 、 | 
数据 、 图 像 、 动 画 、 视 频 点 播 和 声音 信息 , 这 些 信息 者 是 由 许 许多 多 的 Web 服务 器 产生 的 ，| 会 内 
而 每 一 个 Web 服务 器 又 可 以 通过 各 种 方式 与 数据 库 服务 器 连接 , 大 量 的 数据 实际 存放 在 数 一 六 
据 库 服务 器 中 。 客 户 端 除了 WWW 浏览 器 ， 一 般 无 需 任何 用 户 程序 ， 只 需 从 Web 服务 器 
上 下 载 程序 到 本 地 来 执行, 在 下 载 过 程 中 若 过 到 与 数据 库 有 关 的 指令 , 由 Web 服务 器 交 给 | 
数据 库 服务 器 来 解释 执行 ， 并 返回 给 Web 服务 器 ，Web 服务 器 又 返回 给 用 户 。 在 这 种 结构 ， 
中 ， 将 许 许多 多 的 网 连接 到 一 块 ， 形 成 一 个 巨大 的 网 ， 即 全 球 网 。 而 各 个 企业 可 以 在 此 结 | 
构 的 基础 上 建立 自己 的 Intranet。 


2.4.1 B/S 结构 的 优点 


B/S 结构 的 优点 如 下 : 

(1) 具有 分 布 性 特点 ， 可 以 随时 随地 进行 查询 、 浏 览 等 业务 处 理 。 
(2) 业务 扩展 简单 方便 ， 通 过 增加 网 页 即 可 增加 服务 器 功能 。 

(3) 维护 简单 方便 ， 只 需要 改变 网 页 ， 即 可 实现 所 有 用 户 的 同步 更 新 。 
(4) 开发 简单 ， 共 享 性 强 。 


2.4.2 ”B/S 结构 的 缺点 


B/S 结构 的 缺点 如 下 : | 

(1) 个 性 化 特点 明显 降低 ， 无 法 实现 具有 个 性 化 的 功能 要 求 《 个 性 化 的 要 求 取决 于 | 
软件 框架 ， 而 非 架 构 ， 分 享 B/S 软件 就 很 灵活 )。 

(2) 以 鼠标 为 最 基本 的 操作 方式 ， 无 法 满足 快速 操作 的 要 求 〈 如 果 辅 助 于 插件 ， 可 | 
以 用 键盘 快速 操作 )。 

(3) 页 面 动态 刷新 ， 响 应 速度 明显 降低 (分 享 软件 用 分 页 保证 响应 速度 稳定 )。 

(4) 功能 弱化 ， 难 以 实现 传统 模式 下 的 特殊 功能 要 求 。 
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络 B2B《〈 企 业 对 企业 )》 网 上 交易 的 成 功 案例 之 后 ， 也 充分 认识 到 网 络 交易 将 成 为 未 来 商品 
| 交易 的 重要 组 成 部 分 。 所 以 ， 各 个 企业 在 建立 企业 宣传 网 络 的 同时 ， 也 逐步 扩大 企业 自身 
| 的 网 络 销售 渠道 ， 建 立 起 自己 的 电子 商务 网 站 ， 完 成 了 从 B2B 到 B2C 企业 对 个 人 ) 同 


(Eap 项 目 业 全 分 析 


第 3 章 需求 分 析 


3.1 必要 性 与 可 行 性 分 析 


随 着 Intemet 的 发 展 ， 电 子 商 务 已 逐渐 被 大 多 数 企 业 接受 并 认可 。 很 多 企业 在 看 到 网 


| 时 进行 网 络 交易 的 过 渡 ， 大 大 提高 了 企业 生产 效益 。 随 着 硬件 技术 、 网 络 技术 及 网 上 交易 
| 法 规 的 日 趋 完 善 ， 电 子 商 务 将 成 为 企业 销售 经 营 的 主要 渠道 。 


目前 ,可 以 开发 动态 网 站 的 主流 语言 有 PHP、JSP 和 .NET。 这 3 种 主流 Web 开发 技术 


各 有 千秋 ， 其 中 ，PHP 网 络 编程 技术 因 其 安全 、 稳 定 、 易 开发 等 卓越 特性 广 受 人 们 好 评 ， 
| 并 在 整个 Web 开发 领域 应 用 广泛 ， 另 外 ， 利 用 PHP 所 开发 的 Web 程序 支持 多 种 操作 系统 
| 平台 且 有 较 好 的 程序 移植 性 。 


本 电子 商务 网 站 系统 利用 当前 网 站 流行 的 构架 方式 (Apache+MySQL+PHP)， 并 应 用 


Windows 作为 搭载 平台 建立 整个 系统 的 Web 服务 器 。 由 于 Apache、MySQL 与 PHP 具有 
| 良好 的 开源 性 与 免费 性 ， 可 以 为 企业 在 开发 电子 商务 网 站 过 程 中 极 大 地 降低 成 本 并 缩短 开 


3.2 系统 需求 
根据 对 电子 商务 网 站 系统 的 分 析 , 可 以 将 整个 系统 分 为 购物 车 、 用 户 中 心 、 热 门 商 品 、 
商品 评价 等 6 个 部 分 。 电 子 商务 网 站 的 整体 结构 和 各 功能 模块 如 图 3.1 所 示 。 
最 热 商 用 销 订 
吕 时 此 加 刘 兰 
复员 | 委 | 


图 3.1 系统 总 体 功能 图 
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J 
3.3 ”功能 需求 


所 谓 电子 商务 系统 ， 其 实质 就 是 一 个 虚拟 的 购物 超市 系统 。 通 过 对 电子 商务 网 站 实际 | 
的 考察 、 分 析 ， 并 结合 企业 电子 商务 网 站 的 未 来 发 展 需要 ， 要 求 本 系统 具有 以 下 功能 : “| 
(1) 网 站 设计 页 面 要 求 美观 大 方 、 个 性 化 ， 功 能 全 面 ， 操 作 简单 。 


(2) 实现 用 户 登 录 、 注 册 、 找 回 密码 等 用 户 操作 功能 。 

(3) 实现 迅速 查找 商品 功能 。 

(4) 实现 轻松 、 方 便 购物 体验 。 

(5) 实现 商品 分 类 详尽 ， 可 按 不 同类 别 查看 商品 信息 。 

(6) 提供 快速 商品 检索 功能 ， 保 证 数据 查询 的 灵活 性 。 

(7) 实现 商品 查看 、 购 买 商品 功能 。 

(8) 实现 综合 条 件 查询 ， 如 按 用 户 指定 条 件 查询 、 按 关键 字 查询 、 按 会 员 价格 等 条 | 
件 查询 。 | 

(9) 实现 用 户 权限 优惠 等 级 。 


(10) 实现 订单 查询 功能 。 | 
(11) 提供 灵活 、 方 便 的 权限 设置 功能 ， 使 整个 系统 的 管理 分 工 明 确 ， 具 有 易 维护 性 | 


3.4 系统 性 能 要 求 


该 系统 设计 目标 是 开发 一 个 适合 中 小 型 企业 使 用 的 网 上 购物 系统 。 用 户 可 以 在 网 上 迅 | 
速 地 查找 到 自己 喜欢 的 商品 ， 从 而 使 购物 变 得 轻松 、 方 便 。 用 户 在 该 系统 购买 商品 之 后 ， 
只 需 等 待 送 货 上 门 。 对 经 营 者 来 说 可 以 很 好 地 配置 人 力 ， 通 过 网 络 提 高 企业 的 知名 度 。 随 
着 计算 机 网 络 的 高 速 发 展 ， 网 上 购物 将 成 为 以 后 的 发 展 趋势 ， 网 上 消费 将 成 为 一 种 消费 时 | 
尚 。 一 个 优秀 的 网 上 购物 系统 应 该 具备 以 下 性 能 : | 

(1) 商品 信息 的 合理 管理 。 

(2) 方便 易 懂 的 网 上 购物 方法 。 

(3) 商家 与 用 户 的 交流 性 。 

(4) 合理 的 用 户 管理 。 

(5) 安全 的 订单 管理 机 制 。 
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第 4 章 系统 数据 库 设 计 


4.1 数据 库 理 论 基 础 
一 个 成 功 的 信息 管理 系统 ， 是 建立 在 许多 条 件 之 上 的 ， 而 数据 库 是 其 中 一 个 非常 重要 


| 的 条 件 和 关键 技术 。 


信息 管理 系统 所 涉及 的 数据 库 设 计 分 5 个 步骤 : 数据 库 需 求 分 析 、 概 念 设计 、 逻 辑 设 


| 计 、 物 理 设计 与 加 载 测试 。 


数据 库 需求 分 析 的 任务 是 将 业务 管理 单 证 流 化 为 数据 流 ， 划 分 主题 之 间 的 边界 ， 绘 制 


出 DED 图 ， 并 完成 相应 的 数据 字典 。 


概念 设计 的 任务 是 从 DFD 出 发 ， 绘 制 出 本 主题 的 实体 一 关系 图 ， 并 列 出 各 个 实体 与 


| 关系 的 纲要 表 。 


逻辑 设计 的 任务 是 从 E-R 图 与 对 应 的 纲要 表 出 发 ， 确 定 各 个 实体 及 关系 的 表 名 属性 。 
物理 设计 的 任务 是 确定 所 有 属性 的 类 型 、 宽 度 与 取 值 范围 ， 设 计 出 基本 表 的 主键 ， 将 


所 有 的 表 名 与 字段 名 英文 化 (现在 很 多 软件 能 支持 中 文字 段 ， 如 MS SQL Server)， 实 现 物 
| 理 建 库 ， 完 成 数据 库 物理 设计 字典 。 


加 载 测试 工作 贯穿 于 程序 测试 工作 的 全 过 程 ， 整 个 输入 、 修 改 、 查 询 和 处 理工 作 均 可 
视 为 对 数据 库 的 加 载 测试 工作 。 

要 设计 出 一 个 好 的 信息 管理 系统 数据 库 ， 除 满足 系统 所 要 求 的 功能 外 ， 还 必须 遵守 下 
列 原则 : 

(1) 基本 表 的 个 数 越 少 越 好 。 

(2) 主键 的 个 数 越 少 越 好 。 键 是 表 间 连接 的 工具 ， 主 键 越 少 ， 表 间 的 连接 就 越 简单 。 

(3) 字段 的 个 数 越 少 越 好 。 

(4) 所 有 基本 表 的 设计 均 应 尽量 符合 第 三 范式 。 

数据 库 的 设计 中 ， 如 何 处 理 多 对 多 的 关系 和 如 何 设计 主键 ,是 两 个 有 着 较 大 难度 、 需 
要 重点 考虑 的 问题 。 下 面 着 重 从 SQL 应 用 、 数 据 库 设 计 范式 和 查询 优化 等 方面 来 分 析 本 
课题 的 系统 关键 技术 和 实现 难点 并 加 以 解决 。 


4.2 系统 实体 E-R 图 


由 于 实体 之 间 存 在 相互 关系 ， 所 以 用 E-R 图 来 表示 实体 之 间 的 关系 。 考 虑 到 篇 幅 ， 所 
有 实体 或 关系 的 详细 字段 和 关键 字 并 未 给 出 ， 但 在 后 面 将 详细 列 出 数据 库 的 内 容 和 详细 说 
明 。 数 据 库 E-R 图 如 图 4.1 所 示 。 
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图 4.1 数据 库 E-R 图 


4.3 系统 数据 表 设 计 


结合 实际 情况 及 对 用 户 需求 的 分 析 ， 电 子 商 务 系统 shop 数据 库 主 要 包含 admin (管理 | 
员 表 )、user (用 户 信息 表 )、dingdan (用户 订单 表 )、leaveword (用 户 留言 表 )、pingjia( 商 | 
品评 价 表 )、shangpin〈 商 品 信 息 表 )、gonggao〔( 系统 公告 表 )、type〔 商 品 大 类 表 )、ip ( 访 | 
客 耳 记录 表 ) 等 数据 表 。 | 
电子 商务 系统 数据 库 中 主要 数据 表 的 设计 结构 如 表 4.1~ 表 4.9 所 示 。 
表 4.1 admin 表 
字段 名称 
i | | -| 


主键 自动 编号 ID 


| vaha | :5 | | 管理 只 % 
| vachar | 5 和 | | 管 员 但 


表 4.2 user 表 


pwd varchar 用 户 密码 
dongjie int 标记 用 户 是 否 被 冻结 
email Varchar 用 户 E-mail 地 址 
sfzh Varchar 用 户 身份 证 号 
tel Varchar 联系 电话 

用 户 QQ 号 码 


qq varchar 


也 址 


varchar 


varchar 


字段 名 称 数据 类 型 说 明 
youbian varchar 用户 邮编 
Tegtime datetime 用户 注册 时 间 
truename varchar 用户 真实 姓名 


pwdl 


varchar 


表 4.3 dingdan 表 


未 加 密 的 用 户 密码 


字段 名 称 数据 类 型 说 明 
id int 自动 编号 ID 
dingdanhao Varchar 订单 号 
spe varchar 商品 串 
slc Varchar 250 数量 串 
shouhuoren 收 货 人 姓名 
dizhi Varchar 250 送 货 地 址 

oubian 邮编 
{el 联系 电话 
email E-mail 
shff 收 货 方式 
zf 支付 方式 
leaveword | | 用 户 留 言 
time 下 单 时 间 
xiadanren 下 单 人 姓名 
zt 订单 状态 
total | no | s | 价格 总 计 
表 4.4 leaveword 表 

字段 名 称 数据 类 型 说 了 明 
id int 自动 编号 了 D 
userid, int 有 用户 
title Varchar 留言 主题 
time datetime 留言 时 间 
content text 留言 内 容 

字段 名 称 数据 类 型 说 明 
id int 自动 编号 ID 
userid int 用 户外 
title varchar 评价 主题 
time datetime 评价 时 间 
spid int 商品 JD 
content text 评价 内 容 
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y | 

Dd | 

字段 名 称 说 明 
id 自动 编号 D | 
mingcheng 商品 名 称 | 
jianjie 商品 价格 | 


dengii | va | 50 | | 商品 等 级 
xinghao varchar 商品 型 号 
tupian varchar 图 片 路 径 
shuliang int 商品 数量 
cishu i 购买 次 数 
tuijian 是 否 推荐 
ypeid 类 型 ID 

huiyuanjia 会 员 价 
shichangjia 市 场 价 
pinpai 品 牌 

tejia 是 否 特价 


| nm | : 自动 编号 ID 
[am | 用 户 从 
| varchar | 


varchar 留言 主题 
时 间 
留言 内 容 


自动 编号 ID 
商品 大 类 名 


字段 名 称 数据 类 型 说 明 
id | int 自动 编号 ID 


Varchar 访客 卫 


i | atime | 50 | | A 入 市 Wf 
addtime datetime 50 市 时 间 
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第 5 章 系统 设计 


| 电子 商务 系统 的 前 、 后 台 结 构 如 图 5.1 和 图 5.2 所 示 。 


让 子 商务 系统 首页 
nie Wp 


| 


honey pho 


个 人 | Ea pp 人 changeomerpndnie 


oaktt pay 


sey uss 
aeoatgeo pp AN 


3 RS 


he ee 


图 5.2 后 台 文件 结构 图 


| 5.2 系统 功能 模块 设计 


5.2.1 系统 的 功能 模块 


从 电子 商务 网 站 的 基本 功能 角度 考虑 ， 整 个 电子 商务 系统 主要 由 前 台 
J . 428 . 


系统 和 后 台 系 统 


共同 组 成 ， 前 台 系统 主要 由 分 类 商品 展示 、 用 户 登录 、 查 询 和 购物 车 等 模块 构成 。 其 中 ， | 
分 类 商品 展示 模块 包括 最 新 商品 展示 、 推 荐 商品 展示 、 热 门 商品 展示 以 及 商品 分 类 展示 等 | 
功能 ， 登 录 模 块 主要 用 于 实现 用 户 的 账号 注册 、 账 号 登录 等 操作 ;查询 模块 主要 用 于 实现 | 
商品 的 查询 以 及 用 户 订单 号 的 查询 操作 ; 购物 车 模块 主要 用 于 登录 用 户 订购 电子 商务 网 站 | 
中 所 陈列 的 商品 。 后 台 系统 由 公告 管理 、 订 单 管理 、 商 品 管理 和 用 户 管理 等 模块 构成 。 其 | 
中 ， 公 告 管理 模块 包括 更 改 公告 信息 和 添加 公告 信息 操作 ;订单 管理 模块 包括 编辑 订单 和 | 
查询 订单 操作 ;商品 管理 模块 包括 添加 、 修 改 商 品 信息 和 添加 、 管 理 商 品类 别 操作 ， 用 户 | 
管理 模块 包括 用 户 信 息 管理 、 更 改 管理 员 信 息 等 操作 。 | 


5.2.2 系统 功能 模块 特点 


电子 商务 网 站 系统 可 以 根据 不 同 的 模块 实现 基本 的 网 上 商城 功能 ， 该 前 台 系统 可 以 帮 | 
助 用 户 快速 、 方 便 地 浏览 网 站 中 的 商品 ， 并 提供 完善 的 订购 体系 。 另 外 ， 用 户 可 以 通过 查 | 
询 模 块 得 选 商品 信息 ， 以 查找 特定 条 件 商品 。 | 
后 台 管理 系统 为 网 站 管理 人 员 提供 安全 、 稳 定 、 高 效 的 管理 体制 。 整 个 后 台 管 理 系统 | 
具有 层次 分 明 、 方 面 管理 、 易 于 维护 等 功能 特点 。 前 台 系统 与 后 台 系统 共同 组 成 了 一 个 健 | 
全 的 网 上 购物 及 管理 系统 。 | 
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第 6 章 系统 功能 实现 


ED 
6.1 商品 展示 模块 设计 


6.1.1 推荐 商品 展示 


| 单 击 电子 商务 网 站 首页 的 “推荐 商品 ” 超 链接 ， 即 可 进入 推荐 商品 显示 页 面 。 显 示 推 
| 着 商品 的 实现 方法 与 用 户 账号 冻结 /解冻 的 方法 类 似 , 即 在 后 台数 据 库 设置 一 个 代表 推荐 的 
| 字段 名 称 ， 在 添加 每 个 商品 时 ， 如 果 该 商品 为 推荐 商品 ， 则 更 改 该 商品 的 推荐 商品 字段 即 
| 可 实现 。 推 荐 商品 展示 页 面 如 图 6.1 所 示 。 

| 办 


商品 各 称 : 。 兰 反 闪 三 {8 抽 


商品 品牌 :FIFA 商品 型 号 : 了 -1000 

商品 简介 ;FTFA 单 后 机 抽 

上 8 期 ;zoll-z-! 和 余数 量 ; 50 商品 等 组 ;一般 
商场 价 : 。 7500 元 会 员 价 : 7200 元 折扣 : 96% 


“EEC: 
而 及 各: Tar-xo0 
商品 品牌 :SR 两 品 型 号 : 3006 
EE29 商品 简介 : 。 于 尼 公 司 于 2006 年 10 月 发 有 的 荫 三 代 Pl wzSiwtion 便 接 式 手掌 游戏 机 
L5H: 2010-1-1 数量: 255 再 品 等 绷 : 精品 


商场 价 : 
a 
出 中 : 
商品 简介 
上 布 B 期 : 2010-1-1 
商场 价 : 。 世 
本 站 共 到 推荐 产品 3 促 二 页 显示 20 促 第 ! 页 / 共 ; 页 | 


图 6.1 推荐 商品 展示 页 面 


6.1.2 最 新 商品 展示 


| 在 电子 商务 网 站 首页 单 击 导航 栏 中 的 “最 新 商品 ” 超 链接 ， 即 可 进入 最 新 商品 展示 页 

| 面 。 在 该 页 面 中 ， 将 显示 系统 管理 员 最 新 添加 的 10 件 商品 ， 用 户 可 以 查看 商品 名 称 、 商 
品 品牌 、 商 品 简介 、 上 市 日 期 、 商 场 价 以 及 会 员 价格 等 信息 。 已 经 登录 的 用 户 可 以 单 击 “ 放 
| 入 购物 车 ”图 标 将 该 商品 放 入 系统 购物 车 中 ， 来 实现 购物 体验 。 最 新 商品 展示 页 面 的 运行 
| 结果 如 图 6.2 所 示 。 


YE 
商品 名 称 : 。 TS5P-3000 
商品 品 晶 : 商品 天 号 : 3006 
商品 简介 : pr 0 月 发 贡 的 笋 三 代 P1 syStatio> 便 措 式 手 学 蘑 江 机。 
上 市 日 期 :2010-I-! 刺杀 芬 量 : 255 再 品 等 级 : 藉 品 
RE 


YE 


| 图 6.2 最 新 商品 展示 页 面 
J .430 . 


a: 商品 型 号 : W1000 

商品 简介 : 。 FA 章 反 相机 

上 市 昌 期 : 。 2011-2-| 条 浴 量 : 50 商品 等 绍 : 一 般 
请 扬 价 : 。 Ts0m 元 会 员 价 : Tzoo 元 #io: sx 


附录 且 


6.1.3 热门 商品 展示 


在 电子 商务 网 站 首页 单 击 导航 栏 中 的 “热门 商品 ” 超 链 接 , 可 进入 热门 商品 展示 页 面 。 
该 页 面 中 显示 的 是 商品 名 称 、 价 格 等 商品 信息 ， 已 经 登录 的 用 户 可 以 单 击 “ 放 入 购物 车 ” | Ap 
图 标 将 该 商品 放 入 系统 购物 车 中 ， 以 此 来 实现 购物 体验 。 热 门 商品 展示 页 面 的 运行 结果 如 | 全] 


图 6.3 所 示 。 


LE 商品 型 号 : Op emnee 
商品 着 介 : 。 特 们 光电 慑 未 
LBM: 010-1-1 和 二 数量 : 56 商品 等 级: 条 品 


商场 从 :29 元 会 员 价 : 299 元 折扣 :Tay 


* EE 


商品 名称 : 对 万 妆 胆 祖 纪 


:FIA 商品 型 号 : 到-1000 
商品 简介 :FTFA 间 所 机 
上 而 B 风 :2011-2-1 和 全 数量: 50 两 品 每 级 : 一 下 
商场 从 ;TSc0 元 会 内 从 ;7200 :0% 
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图 63 热门 商品 展示 页 面 

6.1.4 商品 分 类 展示 | 

在 电子 商务 网 站 首页 单 击 导航 栏 中 的 “分 类 商品 ” 超 链接 , 可 进入 分 类 商品 展示 页 面 。 | 
该 页 面 可 以 通过 单 击 不 同类 别 的 超 链 接 来 筛选 不 同 的 商品 信息 ， 同 样 该 页 显示 的 是 管理 员 
最 新 添加 的 10 条 商品 信息 ， 用 于 向 用 户 展示 商品 名 称 、 价 格 等 信息 ， 已 经 登录 的 用 户 可 | 
以 单 击 “ 放 入 购物 车 ”图 标 将 该 商品 放 入 系统 购物 车 中 ， 以 此 来 实现 购物 体验 。 商 品 分 类 | 
展示 页 面 的 运行 结果 如 图 6.4 所 示 。 | 


本 类 商品 >) 办 公关 


BB: 44 古 品 所 叶 :09-Tlallocse 
向 旦 箭 介 :特价 光 虹 标 
上 市 其: 200 人 由 量 6 商品 竺 衣 : 彬 品 


商场 从 :360 元 个 员 价 : ceo 元 EH 


国 
商品 名 松 
he 
生 商品 简介 


图 6.4 商品 分 类 展示 页 面 
6.1.5 ”查看 商品 详细 信息 


为 了 让 用 户 全 面 了 解 某 件 商品 ， 本 购物 系统 设置 了 查看 商品 详细 信息 模块 。 选 择 任意 | 
类 别 的 商品 并 单 击 “ 查 看 详情 ” 超 链接 ,可 进入 显示 该 商品 详细 信息 的 页 面 。 在 该 页 面 中 ，| 
用 户 不 仅 可 以 通过 商品 信息 对 该 商品 有 整体 了 解 ， 而 且 还 可 以 发 表 用 户 个 人 评论 ， 根 据 用 | 
户 的 评论 , 管理 人 员 可 以 通过 管理 模块 对 商品 做 部 分 调整 。 查看 商品 详细 信息 页 面 如 图 6.5 | 
所 示 。 | 
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商品 简介 
食 生 | | 康 尼 公司 于 2004 年 10 月 八 布 的 弟 三 人 ?layStatin 便 指 式 手 千 着 沙 机 。 
Amaa | 


内 容 : 


|T 人 了 TSF 郧 过 让 区 昌 SI5000 最 全 了 | 
交代， 轴 作 上 由 用 汪 作 二 


[3 


图 6.5 查看 商品 详细 信息 页 面 


6.2 ”购物 车 模块 设计 


6.2.1 添加 商品 至 购物 车 


| 当 用 户 不 能 决定 是 否 购 买 某 种 商品 时 ， 可 以 单 击 该 商品 信息 中 “ 放 入 购物 车 ”图 标 将 
| 该 商品 先 放 入 购物 车 中 。 添 加 商品 至 购物 车 页 面 的 运行 结果 如 图 6.6 所 示 。 


SHOPPING MALL 

| 电 扩 商务 率 引 入 避 守 且 令 合 全 得 一 
| 当前 用 户 ;mr 注 畏 高 开 ”本 站 首页 量 新 商品 ” 摸 荐 商品 ”热门 商品 。 商品 外 类 ”月 户 注 册 。 用户 中 心 “订单 查询 或 的 购物 车 
| 现在 时 间 :011 年 4 月 20 日 星 其 三。 清 往 入 产品 人称; 


1 

| 章 到 的 ， or 商 吕 名 各 小 县 | 市 场 俐 ”| 会 员 耸 ”| 折 各 | 小 计 

| EL SI-3000 可 | | 1am | 6x | ant 

| 明 恒 电子 南 孝 不 统 光电 有 标 1 39 元 | 289 元 | 73% | 289 元 

| EE FE 


图 6.6 添加 商品 至 购物 车 


国 国 时 


6.2.2 ”查看 购物 车 
用 户 选 购 完 商 品 后 ， 可 以 通过 查看 购物 车 功能 来 查看 当前 购物 车 中 的 商品 信息 。 查 看 


购物 车 页 面 如 图 6.7 所 示 。 
商品 名 称 数量 市 场 价 会 员 价 折扣 小 计 换 作 
PSP-3000 转 | 1250 元 200 元 36% 1200 元 移 除 
光电 忌 标 1 399 元 289 元 T3% 269 元 厦 除 
更 改 商 品 数 量 者 收银 台 清空 购物 车 。。 总 计 : 1459 


图 6.7 查看 购物 车 页 面 
6.2.3 ”操作 购物 车 


| 操作 购物 车 主要 分 为 删除 指定 商品 、 更 改 商 品 数量 和 清空 购物 车 等 操作 。 用 户 进入 购 
| 物 车 页 面 ， 在 显示 已 购买 商品 的 信息 表格 中 ， 可 以 看 到 已 经 放 入 购物 车 的 商品 信息 。 在 相 
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“一 
应 商品 的 “数量 ”文本 框 中 输入 数量 ， 然 后 单 击 “ 更 改 商 品 数 量 ” 可 实现 商品 数量 的 更 改 ; 
单 击 购物 车 商品 表格 中 “操作 ” 栏 的 “删除 ” 超 链接 ， 即 可 执行 删除 指定 商品 的 操作 ;如 | 
果 当 前 登录 用 户 单 击 “ 清 空 购物 车 ” 超 链接 ， 即 可 清空 购物 车 内 的 所 有 商品 。 其 运行 结果 | 
如 图 6.8 所 示 。 | 


的 风物 丰 


图 6.8 操作 购物 车 
6.3 搜索 模块 设计 


6.3.1 简单 搜索 

简单 搜索 设置 在 网 站 导航 下 方 ， 设 置 简单 搜索 的 主要 目的 是 方便 用 户 即时 搜索 查找， | 
以 此 来 第 选 特定 的 商品 信息 。 用 户 只 需 在 产品 名 称 文本 框 中 输入 想 要 了 解 的 商品 信息 的 关 | 
键 字 ， 单 击 “ 立 即 查找 ”按钮 即 可 在 显示 页 中 显示 与 关键 字 匹配 的 产品 信息 。 简 单 搜索 运 | 
行 结果 如 图 69 所 示 。 


现在 时 间 ，2011 年 4 月 2 日 星期 二 请 锁 和 产品 名称: 37 Lea | | ws | 


图 6.9 简单 搜索 
6.3.2 ”高 级 搜索 | 
用 户 如 果 想 进一步 得 到 相关 产品 的 信息 ， 则 可 以 通过 高 级 搜索 对 商品 进一步 得 选单 | 
击 主页 面 中 的 “高 级 查找 ”按钮 即 可 进入 高 级 搜索 页 面 ， 利 用 系统 提供 的 高 级 搜索 功能 可 | 
以 精确 地 定位 到 某 件 商品 。 该 模块 功能 的 实现 是 在 findsp.php 中 完成 的 。 其 运行 页 面 如 图 | 
6.10 所 示 。 | 


x 是 ;| 要 模 间 口 
Sn | 可 FE 本 元 
再 8 [天 司 

开始 查找 


图 6.10 高 级 搜索 
6.4 订单 管理 模块 设计 


6.4.1 查看 订单 | 
管理 员 通 过 后 台 登 录 模 块 进入 后 台 管理 页 面 ， 单 击 “ 订 单 管理 ” 超 链接 即 可 进入 订单 | 
管理 页 面 。 当 用 户 提交 订单 后 ， 系 统管 理 人 员 就 可 以 通过 “查看 订单 ”来 查看 用 户 已 经 提 | 
交 的 订单 ， 在 该 模块 中 ， 管 理 人 员 可 以 同时 查看 多 个 用 户 的 订单 信息 ， 并 可 以 同时 删除 多 | 
个 订单 。 查 看 订单 页 面 如 图 6.11 所 示 。 | 
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订单 下 单 人 | 订货 人 | 全 硕 呈 计 | 人 各 方式。 | 收押 方 式 EEE3 EE 
oii4155 | ww | 三 | 2057 | 同上 支付 | 特 史 过 末 作 全 外 于 ”|| 这 者 | [ 匠 和 | 记 
2011041909333036 加 EE 半 局 区 及 总 和 检 全 已 W 革 | 去 者 | [执行 | 三 
1 1 页 1 | 全 号 本 页 | 


会 内 | 图 6.11 查看 订单 页 面 


6.4.2 ”执行 订单 


| 执行 订单 是 为 了 改变 某 订单 的 当前 状态 ， 从 而 使 管理 人 员 能 够 及 时 、 有 效 地 处 理 每 个 
| 用 户 的 订单 , 并 记录 当前 订单 的 处 理 状 态 , 在 查看 订单 页 面 选中 要 操作 的 订单 号 , 单 击 “ 执 
| 行 ”按钮 即 可 进入 订单 操作 页 面 ， 如 图 6.12 所 示 。 


休 间 入 言 ;全 本 演 设 有 了 大 的 ?请 名 好 ,这 此 兴 ? 


图 6.12 执行 订单 页 面 
6.4.3 打印 订单 


在 查看 订单 页 面 单 击 指定 商品 后 的 “查看 ”按钮 即 可 进入 订单 预览 页 面 ， 在 该 页 面 单 击 
“打印 ”或 “打印 预览 ”按钮 即 可 执行 相应 操作 。 打 印 订单 页 面 的 运行 结果 如 图 6.13 所 示 。 


洋 革 方式: 特 风 和 # 进 袜 付 施 式 : 网 上 支付 
er ot 汇 蒜 时 注 明 人 的 洒 音 号 ! 汇 区 后 读 及 对 通知 我 们 
A : 2011-0¢-20 11:44:11 


图 6.13 打印 订单 页 面 
6.4.4 查找 订单 


| 系统 管理 员 可 以 通过 单 击 “ 查 询 订单 ” 超 链接 进入 查找 页 面 。 为 了 便于 系统 管理 员 管 
| 理 订单 ， 该 购物 系统 提供 了 订单 查找 模块 ， 系 统管 理 员 在 相应 的 文本 框 中 输入 下 单 人 姓名 
| 和 订单 号 后 ， 单 击 “ 查 找 ” 按 钮 即 可 执行 订单 查找 操作 。 查 找 订单 页 面 如 图 6.14 所 示 。 
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下 订单 人 迁 名 


| 
四 Ta 
四 ao 
加 昌 
加 区 Tz00 | 贡 到 R 和 | 
m | nana Lee | roo eimaice 


6.S 商品 管理 模块 设计 


6.5.1 添加 商品 信息 


通过 添加 商品 信息 这 一 模块 ， 
该 模块 页 面 如 图 6.15 所 示 。 


图 6.14 查找 订单 页 面 


系统 管理 人 员 可 以 将 新 上 市 的 商品 添加 到 购物 系统 中 ， 


1°01| 
商品 种。 | 这 记 丰 外 肌 
上 RN 间 : fr 可 F/I 
人 人格 抽 声 从 :5599 元 会员 价 : 585 元 
向 品类 型; 了 
avs: [i 
EE 
两 中 号 :| 二 50 
是 百 愉 茶 本 
商品 光量 :上 
MRD: Enema rtine Ai EGG 
ia 证 10 月 上 市 的 要 所管 记 本 电 及 村 人 优惠 中 可 
商品 笛 介 
EE 


6.5.2 ”修改 商品 信息 


图 6.15 添加 商品 信息 


修改 商品 信息 页 面 几 乎 和 添加 商品 信息 页 面 完全 一 样 ， 如 果 修改 商品 成 功 ， 则 弹出 如 | 


图 6.16 所 示 的 对 话 框 。 


Microsoft Internet Explore EE: 


图 6.16 商品 修改 成 功 提示 对 话 框 


6.5.3 删除 商品 信息 


为 了 管理 方便 ， 本 系统 设计 时 采用 了 能 够 同时 删除 多 件 商品 的 方式 ， 这 主要 考虑 到 系 | 
统 中 的 商品 可 能 较 多 ， 一 次 淘汰 的 商品 也 可 能 很 多 ， 如 果 一 件 一 件 地 删除 会 浪费 大 量 的 操 | 
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| 和 ~ 人 人 rr 


作 时 间 ， 采 用 本 系统 的 删除 方式 只 需 选 中 欲 删除 商品 前 的 复 选 枉 ， 选 择 完毕 后 ， 单 击 “ 删 
| 除 选 择 ” 按 扭 即 可 完成 删除 多 项 商品 的 任务 。 完 成 该 模块 的 页 面 如 图 6.17 所 示 。 


ff | 各 过 币 条 | 市 场 从 | 会 员 价 加 和 时 间 氛 作 
全 | | 人 
SE | 0 KE ED 5 | 1 | wm 9 2010-1-1 
| oc 光电 民 标 4 lrrmaws:| 2 | 3 | ws z 2010-11 EE 
口 等 记 本 电 座 可 果 | 20lzlstz | 10 5 4 0 20F1 | 
过 择 | 重新 渤 拓 | 本 站 共有 各 物 4 件 每 页 明示 20 件 第 1 页/ 共 1 页 1 


图 6.17 删除 商品 信息 页 面 
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第 7 章 结 论 


通过 实际 的 调查 和 应 用 ， 可 以 看 出 本 电子 商务 系统 已 经 基本 满足 了 行业 的 设计 要 求 ， 


通过 Web 技术 实现 了 电子 商务 的 基本 功能 。 但 是 ， 在 实际 应 用 调查 中 ,发 现 整个 系统 仍 有 用 芭 亿 : 
不 足 和 缺陷 ， 需 要 对 程序 进一步 改进 。 但 在 应 用 的 整体 反馈 中 ， 与 预期 希望 差别 不 大 ， 基 | 


本 达到 了 预期 效果 。 


本 设计 以 B/S 系统 作为 基本 结构 ， 应 用 PHP 相关 技术 ， 结 合 CSS、 JavaSeript 等 主流 | 
技术 实现 完整 的 电子 商务 网 站 系统 。 通 过 行业 调查 ， 围绕 主流 Web 开发 应 用 技术 , 结合 电 | 
子 商 务 本 身 需 求 ， 对 整个 系统 的 大 体 实现 过 程 进行 了 讲解 。 从 系统 的 稳定 性 与 安全 性 角度 | 


考虑 ， 数 据 库 部 分 采用 MySQL， 在 整个 开发 过 程 中 降低 了 成 本 。 
在 整个 系统 设计 过 程 中 ， 遇 到 了 以 下 问题 : 


(1) 系统 连接 数据 库 时 ， 如 果 函 数 mysql_connect0 中 参数 填写 错误 ， 则 会 导致 系 统 | 


无 法 与 后 台数 据 库 连接 。 


(2) PHP 版 本 兼容 性 问题 。 在 低 版 本 中 开发 的 程序 可 能 会 在 PHP 高 版 本 运行 时 时 输出 | 


警告 提示 。 
(3) 编码 格式 问题 。 从 数据 库 中 提取 的 汉字 可 能 显示 成 乱码 。 


示 错 误 。 


加 了 商品 类 别 选择 功能 ， 使 网 站 整体 结构 更 加 清晰 ， 并 取得 了 预期 测试 结果 。 


对 于 各 个 电子 商务 实际 应 用 情况 ， 该 系统 中 部 分 模块 仍 需 要 根据 个 体 因素 进一步 调 下 | 


和 改进 。 该 电子 商务 网 站 系统 仍 有 待 于 完善 。 
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(4) 如 果 用 户 留言 内 容 包含 空格 、“&”、 回 车 等 特殊 字符 ， 在 前 台 可 能 无 法 显示 或 显 | 


总 体 来 说 ， 本 程序 设计 还 是 成 功 的 。 不 仅 满足 了 电子 商务 网 站 的 基本 需求 ， 同 时 也 添 | 


(ip 项 目 业 全 分 析 
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附录 且 SS 


致谢 


| 名 
毕业 设计 是 我 们 在 大 学 阶段 所 做 的 最 后 一 件 事 ， 也 是 很 重要 的 一 件 事 。 它 不 仅 给 我 们 
的 大 学 生涯 甚至 学 生生 涯 画 上 了 一 个 完满 的 句号 , 而且 也 通过 动手 实践 给 自己 上 了 在 大 学 | 
的 最 后 一 堂 课 ， 通 过 它 所 学 到 的 东西 对 我 们 以 后 的 发 展 有 莫大 的 帮助 。 | 
毕业 设计 并 非 一 帆 风 顺 ， 之 中 也 遇见 过 困难 ， 经 历 过 挫折 ， 我 也 曾 懒惰 过 、 喜 悦 过 、 | 
苦恼 过 ， 也 曾经 感慨 “ 书 到 用 时 方 恨 少 ” 毕业 设计 的 日 子 会 让 我 久久 难忘 。 实 习 的 过 程 | 
让 我 对 本 专业 的 知识 有 了 新 的 认识 。 在 以 往 四 年 的 学 习 过 程 中 ， 我 只 片面 地 注重 了 理论 知 | 
识 的 识 记 与 分 析 ， 而 忽略 了 动手 能 力 的 培养 。 这 个 实际 题目 使 我 才 真正 发 现 只 有 一 些 浅 洲 | 
的 基础 理论 是 远 远 不 够 的 ， 只 有 理论 和 实践 相 结 合 才 真正 合格 。 
在 这 里 ， 我 由 更 地 感谢 半年 来 帮助 过 我 的 各 位 老师 ， 正 是 有 了 他 们 的 热心 帮助 和 耐心 | 
指导 ， 我 才 会 认识 到 自己 的 不 足 ， 在 实践 中 不 断 改正 自己 犯 下 的 错误 ， 使 得 我 的 毕业 设计 | 
能 够 顺利 完成 。 
我 更 要 感谢 我 的 指导 教师 XX 老师 ， 每 当 我 遇 到 困难 难以 解决 时 ， 他 总 是 给 我 细致 入 
微 的 指导 ， 鼓 励 我 耐心 地 思考 遇 到 的 问题 ， 引 导 我 积极 地 寻找 解决 问题 的 方法 ， 从 他 身上 
我 看 到 了 一 个 老师 的 敬业 精神 ， 在 这 里 我 诚挚 地 感谢 XX 老师 对 我 的 教育 和 培养 。 
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项 目 案 例 分 析 


附录 A” 主 程序 


<?php 
include("top.php"); 

> 

<table width="800" height="438" border="0" align="center" cellpadding="0" cellspacing= "0"> 
<tr> 


<td width="200" height="438" valign="top" bgcolor="#E8E8E8"> 
<div align="center"> 
<2php include("left.php");?> 
</div></td> 
<td width="10" background="images/line?2.gif'>&nbsp;</td> 
<td width="590" valign="top"> 
<table width="590" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td width="15" rowspan="2">&nbsp;</td> 
<td height="25" colspan="2"> 
<div align="left"><img src="images/yqlj.gif' width="250" height="25"></div> 
</td> 
</tr> 
<!-- 略 部 分 代码 --> 
<tr> 
<td height="18" valign="top"><div align="center"> <a href="http://www.mingrisoft. 
com/about.asp">MRSOFT</a><a href="http://d.baidu.com"></a> </div></td> 
<td valign="top"><div align="center"> <a href="http://www.mingrisoft. com/about.asp"> 
MRSOFT</a><a href="http://www.tom.com"></a><br> 
</div></td> 
<td valign="top"><div align="center"><a href="http://www.mingrisoft. com/about.asp"> 
MRSOFT</a><a href="http://www.hao123.com"></a></div></td> 
<td valign="top"> 
<div align="center"><a href="http://www.mingrisoft.com/about.asp">MRSOFT</a><a 
href="http://cn.yahoo.com"></a> </div></td> 
<td valign="top"><div align="center"><a href="http://www.mingrisoft. com/about.asp"> 
MRSOFT</a><a href="http://download.lycos.com.cn/"></a></div></td> 
| <td valign="top"><div align="center"><a href="http:/www.mingrisoft. comy/about. 
asp">MRSOFT</a></div></td> 
</tr> 
</table></td> 
</tr> 
<tr> 
<td height="10" col ="3" background="images/linel.gif'’></td> 
</t> 
</table> 
<table width="556" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td height="25"><img src="images/tjsp.gif' width="500" height="25"></td> 
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</tr> 
</table> 
<table width="590" border="00" align="center" cellpadding="0" cellspacing="0"> 
<tr> 


<td height="110"><table width="530" height="110" border="0" align="center" cellpadding= 
"0" cellspacing="0"> 
<tr> 
<td width="265"> 
<?php 
$sql=mysql_query("select * from shangpin where tuijian=1 order by addtime desc limit 0,1"); 
$info=mysql fetch array($sq]l); // 返 回 查 询 信息 
这 $info 一 false) // 判 断 是 否 有 返回 信息 
{ 
echo "本 站 暂 无 推荐 产品 1"; 
}else { 
> 
<table width="255" border="0" cellspacing="0" cellpadding="0"> 
<tr> 


<td width="130" rowspan="6"><div align="center"> 
<?php 
f(trim($info[tupian]=="")) /判断 是 否 存 在 图 片 


由 
echo " 暂 无 图 片 "; 
}else{ 
?> 
<img src="<?php echo $info[tupian];?>" width="130" height="100" border="0"> 
<?php 
} 
?> 
</div></td> 
<td width="20" height="16">&nbsp:</td> 
<td width="113"><font color="EF9C3E"> 【<?php echo $info[mingcheng]:?>}】 </font></td> 
</tr> 
<tr> 
<td height="16">&nbsp;</td> 
<td><font color="910800">【 市 场 价 ;<?php echo $info[shichangjia]:?>】</font></td> 
</tr> 
<tr> 
<td height="16">&nbsp;</td> 
<td><font color="DD4679">【 会 员 价 : <?php echo $info[huiyuanjia];?>】</font></td> 
</tr> 
<tr> 
<td height="16">&nbsp:</td> 
<td>【<a hre 全 "lookinfo php?id=-<?php echo $info[id];?>"> 查 看 信息 </a>】</td> 
</tr> 
<tr> 
<td height="16">&nbsp:</td> 
<td> 【<a href="addgouwuche.php?id=<?php echo $info[id]:?>"> 放 入 购物 车 </a>】</td> 
</tr> 
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<td height="16">&nbsp:</td> 

<td><font color="13589B">【 剩 余数 量 : 
<?php 
if(($info[shuliang]-$info[cishu])>0) 
{ 


echo ($info[shuliang]-$info[cishu]); 


} 

2>】 </font></td> 
</tr> 

</table> 

<!-- 省 略 部 分 代码 --> 
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附录 B 子 程 序 


<?php 
session start(); 
if($_SESSION["usermame"]=—"") // 判 断 当前 用 户 是 否 登 录 
{ 
echo"<script> 
alert(' 请 先 登录 ， 后 购物 !"):history.backO; 
</script>"; 
exit: 
} 
> 
<?php 
include("top.php"); 1/ 加载 top.php 文件 
?> 
<table width="800" height="438" border="0" align="center" cellpadding="0" cellspacing="0"> | 
<tr> | 
<td width="200" height="438" valign="top" bgcolor="#E8E8E8"><div align="center"> | 


<2php include("left.php");?> 
</div></td> 
<td width="10" background="images/line2.gif">&nbsp;</td> 
<td width="590" valign="top"><table width="550" height="10" border="0" align="center" 
cellpadding="0" cellspacing="0"> 
<tr> 
<td>&nbsp;</td> 
</tr> 

</table> 
<table width="500" border="0" align="center" cellpadding="0" cellspacing="0"> 

<form name="forml1" method="post" action="gouwul.php"> 

<tr> 
<td height="25" bgcolor="#555555"> 

<div align="center" style="color: #FFFFFF"> 
<?php echo $_SESSION[username]:?> 的 购物 车 
</div> 
</td> 

</tr> 

<tr> 

<td bgcolor="#555555"> 

<table width="500" border="0" align="center" cellpadding="0" cellspacing="1"> 


<?php 

$_SESSION["total"]=""; // 注 册 SESSION 变量 并 赋 空 值 
if($_GET[qk]—"yes") // 判 断 是 否 提 交 
4 
$_SESSION["producelist"]="": /注册 SESSION 变量 并 赋 空 值 
$_SESSION["quatity"]=""; 
} 
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A 
2 
// 分 离 SESSION 变量 中 的 商品 
Sarraygwc=explode("(@",$_SESSION[producelist]); 
$s=0; 
for($i=0;$i<count($arraygwe);$i++) // 通 过 循环 获得 商品 数量 
由 

$s+=intval($arraygwc[$1i]):; 


} 
is 一 0) /电网 物 车 是 为 


{ 
echo "<tr>"; 
echo" 
<td height='25' colspan='6' bgcolor='#FFFFFF' align='center> 您 的 购物 车 为 空 !</td>"; 
echo"</tr>"; 
}else{ 
?> 
<tr> 
| <td width="125" height="25" bgcolor="#FFFFFF"><div align="center'> 商品 名 称 
| div></d> 
| <td width="52" bgcolor="#EFFFFF"><div align="center"> 数 量 </div></td> 
<td width="64" bgcolor="#EFFFFF"><div align="center"> 市 场 价 </div></td> 
<td width="64" bgcolor="#FFFFFF"><div align="center"> 会 员 价 </div></td> 
<td width="51" bgcolor="#FFFFFF"><div align="center"> 折 扣 </div></td> 
<td width="66" bgcolor="#FFFFFF"><div align="center"> 小 计 </div></td> 
<td width="71" bgcolor="#FFFFFF"><div align="center"> 操 作 </div></td> 
</tr> 
<?php 
S$total=0; 
// 分 离 SESSION 变量 中 的 商品 
$array=explode("@",$_SESSION[producelist]): 
$arrayquatity=explode("(@",$_SESSION[quatity]):; 
while(list($name,$value)=each($_POST)) 
/循环 获取 POST 变量 中 的 数据 
{ 
for($i=0;$i<count($array)-1:$i++) 
{ 
这 ($array[$i) 一 $name) 
{ 


Sarrayquatity[$i]=$value; 
} 
} 
} 
$_SESSION[quatity]=implode("@",$arrayquatity); 
for($i=0:$i<count($array)-1:$i++) 
{ 
Sid=$array[$1i]; 
$num=$arrayquatity[$1]; 
if($id!="") // 如 果 获 得 记 不 为 空 


{ 
$sql=mysql_ query("select * from shangpin where id=".$id."",$conn);// 执 行 数据 库 查询 
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// 获 取 总 数 


sql_fetch array($sql); 
NI"total"]=Stotal; 


// 将 总 数 赋值 给 SESSION 变量 
/省 略 部 分 代码 
ye 


S$totall=$num*$info[huiyuanjial: 


// 获 取 会 员 应 付 价格 
S$total+=$totall; 


$_SESSIO! 


$1 
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